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表,如果没有,就右键表,选择刷新就出现了。
在这里插入图片描述
2.点击STUDENT进入,找到笔的图案并点击进入。
在这里插入图片描述
3.找到Ssex大小,修改2为3
在这里插入图片描述

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

解决完成

重新插入

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

输出

1行已插入。
  • 0
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值