本机环境
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表,如果没有,就右键表,选择刷新就出现了。
2.点击STUDENT进入,找到笔的图案并点击进入。
3.找到Ssex大小,修改2为3
二. 用标志代替
比如1代表男性,2代表女性,又或者用M代表男性,F代表女性。
解决完成
重新插入
INSERT INTO student VALUES ('20200526','属性2',20,'男','计算机');
输出
1行已插入。