Oracle数据库建表与插入数据

Oracle数据库建表和数据插入

    • 本机环境
    • 表的建立
      • 插入数据

本机环境

windows10-64位
oracle12c
时间:2020-05-26
使用SQL Developer

表的建立

create table tableName
(
属性名  类型 约束,
属性名  类型 约束,
.
.
.
属性名  类型 约束

);

如:

 CREATE TABLE Student
        (
         Sno    varchar2(17)  primary key,
         Sname  varchar2(10) not null UNIQUE,        
         Sage   INT,
         Ssex   char(2) CHECK(Ssex IN ('男','女') ), 
         Sdept  varchar2(20)
         );

输出

Table STUDENT 已创建。

约束条件的意思:
primary key: 主码(不能为空且唯一)
not null: 非空
unique: 唯一
check(Ssex in (‘男’,‘女’)): Ssex值只能是男或女。

插入数据

INSERT INTO tableName VALUES (属性1,属性2,属性3,属性4,属性5);

如上面建好的表插入数据如下:

INSERT INTO student VALUES ('20200526','属性2',20,'男','计算机');

输出

在行: 1 上开始执行命令时出错 -
INSERT INTO student VALUES ('20200526','属性2',20,'男','计算机')
错误报告 -
SQL 错误: ORA-12899: 列 "CAIONE"."STUDENT"."SSEX" 的值太大 (实际值: 3, 最大值: 2)
...

这是由于导出的文件所运行的Oracle,和导入所运行的Oracle机器字符集不相同导致的,在UTF-8中有的汉字占三个字节,并不是所有的都占两个字节。
解决方法
一.可以修改Ssex的类型为char(3)
1.找到STUDENT表,如果没有,就右键表,选择刷新就出现了。
Oracle数据库建表与插入数据_第1张图片
2.点击STUDENT进入,找到笔的图案并点击进入。
Oracle数据库建表与插入数据_第2张图片
3.找到Ssex大小,修改2为3
Oracle数据库建表与插入数据_第3张图片

二. 用标志代替
比如1代表男性,2代表女性,又或者用M代表男性,F代表女性。

解决完成

重新插入

INSERT INTO student VALUES ('20200526','属性2',20,'男','计算机');

输出

1行已插入。

你可能感兴趣的:(oracle)