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)values什么意思
...
这是由于导出的⽂件所运⾏的Oracle,和导⼊所运⾏的Oracle机器字符集不相同导致的,在UTF-8中有的汉字占三个字节,并不是所有的都占两个字节。
解决⽅法
⼀.可以修改Ssex的类型为char(3)
1.到STUDENT表,如果没有,就右键表,选择刷新就出现了。
2.点击STUDENT进⼊,到笔的图案并点击进⼊。
3.到Ssex⼤⼩,修改2为3
⼆. ⽤标志代替
⽐如1代表男性,2代表⼥性,⼜或者⽤M代表男性,F代表⼥性。解决完成
重新插⼊
INSERT INTO student VALUES ('20200526','属性2',20,'男','计算机');
输出
1⾏已插⼊。