问题1:学号重复了,数据还可以插入成功
使用主键约束:学号是唯一标识一条数据的,所以必须唯一且不能为空
---(1)、在确定为主键的字段后添加 primary key关键字
---(2)、在创建表的后面使用:constraints pk_表名_字段名 primary key(字段名)
--(3)、在创建表后使用 alter table 表名 add constraints pk_表名_字段名 primary key(字段名);
--删除主键:alter table 表名 drop constraints pk_表名_字段名
问题2:姓名可以为空。
使用非空约束
---(1)、创建表的时候在字段后面添加not null
---(2)、在创建表字段后使用 constraints ck_表名_字段名 check(字段名 is not null) 了解
--(3)、在创建表后使用alter table 表名 modify 字段名 类型 not null;
---(4)、修改字段可以存储空值:alter table 表名 modify 字段名 类型 null;
问题3:性别不但可以为空,还可以为其他不知道的字符
使用检查约束
---(1)、创建表的时候在字段后使用 default 值 check(条件),
---------但是会允许空值的出现,并且默认值只有在字段不声明的情况下生效
---(2)、在创建表所有字段后使用:constraints ck_表名_字段名 check(条件)
---(3)、在创建表后使用:alter table 表名 add constraints ck_表名_字段名 check(条件)
问题4:年龄可以超过200
--使用检查约束条件
问题5:qq号一致
使用唯一约束
--(1)、在字段后直接使用unique关键字
--(2)、在所有字段后使用:constraints uk_表名_字段名 unique(字段名)
--(3)、 alter table 表名 add constraints uk_表名_字段名 unique(字段名)
--删除唯一约束:alter table 表名 drop constraints uk_表名_字段名
                        

使用外键约束
--(1)、在字段后使用 references 参照表表名(参照字段)
--(2)、在所有字段后使用 constraints fk_表名_字段名 foreign key(字段名) references 参照表名(参照字段名)
--(3)、在创建表后使用alter table 表名 add constraints fk_表名_字段名 foreign key(字段名) references 参照表名(参照字段名)
--删除外键 alter table 表名 drop constraints fk_表名_字段名

在删除父表数据的时候需要先删除子表数据?
解决方式1:先解除主外键关联,然后删除数据,再然后添加主外键关联
解决方式2:在创建外键的时候使用级联操作。
--在创建外键时 on delete cascade
--在创建外键时 on delete set null
怎么选取外键?
一般将主表的主键作为子表的外键
外键的值能为 not null? 不建议在外键后使用非空约束

  

1、主键约束

三种方式主键约束方式

create table student(
sno number(10) primary key,
sname varchar2(100),
sage number(3),
ssex char(4),
sbirth date,
sqq varchar2(30)
);
create table student(
sno number(10),
sname varchar2(100),
sage number(3),
ssex char(4),
sbirth date,
sqq varchar2(30),
constraint pk_student_sno primary key(sno) ---添加主键约束
);
create table student(
sno number(10),
sname varchar2(100),
sage number(3),
ssex char(4),
sbirth date,
sqq varchar2(30)
);
alter table student add constraint pk_student_sno primary key(sno);
alter table student drop constraint pk_student_sno;
select * from student for update;
drop table student;

非空约束

三种方式

create table student(
sno number(10) primary key,
sname varchar2(100) not null,
sage number(3),
ssex char(4),
sbirth date,
sqq varchar2(30)
);
create table student(
sno number(10) primary key,
sname varchar2(100),
sage number(3),
ssex char(4),
sbirth date,
sqq varchar2(30),
constraints ck_student_sname check(sname is not null)
);

 

create table student(
sno number(10) primary key,
sname varchar2(100),
sage number(3),
ssex char(4),
sbirth date,
sqq varchar2(30) );

  alter table student add constraint ch_student_sname check(sname is not null);  

alter table student drop constraint ch_student_sname

 

检查约束

create table student(
sno number(10) primary key,
sname varchar2(100) not null,
sage number(3) check(sage<150 and sage>0),
ssex char(4) check(ssex ='男' or ssex = '女'),
sbirth date,
sqq varchar2(30)
);
create table student(
sno number(10) primary key,
sname varchar2(100) not null,
sage number(3),
ssex char(4) check(ssex ='男' or ssex = '女'),
sbirth date,
sqq varchar2(30),
constraint ch_student_sage check(sage<150 and sage>0)
);

  

create table student(
sno number(10) primary key,
sname varchar2(100) not null,
sage number(3),
ssex char(4) check(ssex ='男' or ssex = '女'),
sbirth date,
sqq varchar2(30)
);

alter table student add constraint ch_student_sage check(sage<150 and sage>0);

alter table student drop constraint ch_student_sage;

 唯一约束

create table student(
sno number(10) primary key,
sname varchar2(100) not null,
sage number(3) check(sage>1 and sage < 200) ,
ssex char(4) check(ssex ='男' or ssex = '女'),
sbirth date,
sqq varchar2(30) unique
);

  插入俩次报错

insert into student values(6,'关晓彤003',18,'女',to_date('1998-05-26','yyyy-mm-dd'),'989');
create table student(
sno number(10) primary key,
sname varchar2(100) not null,
sage number(3) check(sage>1 and sage < 200) ,
ssex char(4) check(ssex ='男' or ssex = '女'),
sbirth date,
sqq varchar2(30),
constraint ch_student_sqq unique(sqq)
);

 

第三种
create table student(
sno number(10) primary key,
sname varchar2(100) not null,
sage number(3) check(sage>1 and sage < 200) ,
ssex char(4) check(ssex ='男' or ssex = '女'),
sbirth date,
sqq varchar2(30)
);

  

alter table student add constraint un_student_sqq unique(sqq);

外键约束

选取--一般选取 父表的主键做为字表的外键

缺点--无法删除班级3的信息

  

create table student(
sno number(10) primary key,
sname varchar2(100) not null,
sage number(3) check(sage>1 and sage < 200) ,
ssex char(4) check(ssex ='男' or ssex = '女'),
sbirth date,
sqq varchar2(30) unique,
cno number(10) references clazz(cno) --可以起不同的名,是映射关系
); create table clazz (
cno number(10) primary key,
cname varchar(100) not null,
cdesc varchar(200)
); insert into student values(11,'关晓彤003',18,'女',to_date('1998-05-26','yyyy-mm-dd'),'11',1);
insert into student values(12,'关晓彤003',18,'女',to_date('1998-05-26','yyyy-mm-dd'),'22',1);
insert into student values(13,'关晓彤003',18,'女',to_date('1998-05-26','yyyy-mm-dd'),'333',2);
insert into student values(14,'关晓彤003',18,'女',to_date('1998-05-26','yyyy-mm-dd'),'444',2); insert into clazz values(1,'java','java');
insert into clazz values(2,'pathon','pathon'); select * from student s inner join clazz c on s.cno = c.cno;
insert into student values(15,'关晓彤003',18,'女',to_date('1998-05-26','yyyy-mm-dd'),'55',3); 
create table student(
sno number(10) primary key,
sname varchar2(100) not null,
sage number(3) check(sage>1 and sage < 200) ,
ssex char(4) check(ssex ='男' or ssex = '女'),
sbirth date,
sqq varchar2(30) unique,
cno number(10),--可以起不同的名,是映射关系
constraint fk_student_cno foreign key(cno) references clazz(cno)
);

  

create table student(
sno number(10) primary key,
sname varchar2(100) not null,
sage number(3) check(sage>1 and sage < 200) ,
ssex char(4) check(ssex ='男' or ssex = '女'),
sbirth date,
sqq varchar2(30) unique,
cno number(10)--可以起不同的名,是映射关系
);

alter table student add constraint fk_student_cno foreign key(cno) references clazz(cno);
alter table student drop constraint fk_student_cno;

  

on delete cascade 删除父表时候,字表一起删除
delete set null 删除父表时候,字表设置为null
alter table student add constraint fk_student_cno foreign key(cno) references clazz(cno) on delete cascade;
alter table student add constraint fk_student_cno foreign key(cno) references clazz(cno) on delete set null;

  

 

oracle--约束(主键、非空、检查)的更多相关文章

  1. Oracle删除主键约束的同时删除索引

    继续昨天的折腾(Oracle修改主键约束),删掉主键约束后,发现唯一索引并未删掉.仔细看了下,主键约束跟唯一索引名称不一样,这说明是先创建了唯一索引,后创建的主键约束.我们来试验下: SQL> ...

  2. Oracle 设置主键自增长__Oracle

    转自:https://yq.aliyun.com/ziliao/258074 如果想在Oracle数据库里实现数据表主键自增,我们似乎没有办法像MySql般直接定义列的属性来实现.不过对于这个数据库的 ...

  3. 根据oracle的主键列生成SQLserver的主键

    根据oracle的主键列生成MsSQLServer的主键列 select 'alter table  ' || cu.table_name ||'  add constraint  '||' PK_' ...

  4. MyBatis自动获取主键,MyBatis使用Oracle返回主键,Oracle获取主键

    MyBatis自动获取主键,MyBatis使用Oracle返回主键,Oracle获取主键 >>>>>>>>>>>>>> ...

  5. Oracle通过主键id删除记录很慢

    问题描述: Oracle通过主键id删除2000条记录很慢,需要花费十二分钟. 解决过程: 1.首先查看SQL的执行计划,执行计划正常,cost只有4,用到了主键索引. 2.查看等待事件, selec ...

  6. [每日一题] OCP1z0-047 :2013-08-18 禁用启用约束――主键与外键 ..................................61

    正确答案:C 根据题意,测试结果如下: 1.创建表emp,并且设emp_no字段为主键,设mgr_no字段为外键. gyj@MYDB> create table emp 2 (emp_no nu ...

  7. Oracle根据主键获取对应表,Oracle根据外键获取相关表

    Oracle根据主键获取对应表 select * from user_constraints a, USER_CONS_COLUMNS b where a.CONSTRAINT_TYPE = 'P' ...

  8. oracle中主键自增

    oracle中主键自增 下面用一个例子来说明自增主键的创建: 1.建用户数据表 drop table dectuser; create table dectuser( userid integer p ...

  9. oracle 新增主键

    alter table tablename add constraint pk_tablename primary key (column1,column2,...); 可以新增单主键或联合主键: 新 ...

  10. oracle 数据库 主键索引重建

    oracle 数据库 主键索引重建 alter table table_name drop primary key; alter table table_name add constraint pk_ ...

随机推荐

  1. Springboot配置文件占位符

    一.配置文件占位符 1.application.properties server.port=8088 debug=false product.id=ID:${random.uuid} product ...

  2. wepy-wxss报错

    慢慢积攒下wepy 的一些BUG吧 1.页面在page目录下明明删除了某个子页面文件,打开wepy却一直报错!wxml报错或者wxss报错,提示的页面我为了排错都直接delete掉了,还是报错???思 ...

  3. ESP8266-01

    我的模块购买地址  https://buyertrade.taobao.com/trade/detail/tradeSnap.htm?tradeID=460212770243341548&sn ...

  4. 6392. 【NOIP2019模拟2019.10.26】僵尸

    题目描述 题解 吼题但题解怎么这么迷 考虑一种和题解不同的做法(理解) 先把僵尸离散化,h相同的钦(ying)点一个大小 (可以发现这样每种情况只会被算正好一次) 计算完全被占领的方案,然后1-方案/ ...

  5. [luogu]P1053 篝火晚会[数学][群论]

    [luogu]P1053 篝火晚会 题目描述 佳佳刚进高中,在军训的时候,由于佳佳吃苦耐劳,很快得到了教官的赏识,成为了“小教官”.在军训结束的那天晚上,佳佳被命令组织同学们进行篝火晚会.一共有n个同 ...

  6. Form 表单用 Ajax 提交数据并用 jQuery Validate 验证

    表单填写需要验证可用插件 jQuery Validate 提交数据使用 Ajax 可操控性得到提到 注意:请自行引入 jQuery 和 jQuery Validate HTML 代码 <form ...

  7. C# 创建临时文件(转帖)

    1. 在临时文件只能够创建一个临时文件并返回该文件的完整路径 // 在临时文件只能够创建一个临时文件并返回该文件的完整路径: // C:\Documents and Settings\YourName ...

  8. D1. Kirk and a Binary String (easy version)

    D1. Kirk and a Binary String (easy version) 01串找最长不降子序列 给定字符串s,要求生成一个等长字符串t,使得任意l到r位置的最长不降子序列长度一致 从后 ...

  9. 音频学习(一)-离线播放(AVAudioPlayer)

    最后更新:2017-05-23 方法 - (nullable instancetype)initWithContentsOfURL:(NSURL *)url error:(NSError **)out ...

  10. [CSP-S模拟测试]:串串香(KMP)

    题目传送门(内部题75) 输入格式 输入文件$ccx.in$ 每个输入文件包含多组测试数据.输入文件的第一行为一个整数$T$,表示数据组数.接下来$T$行,每行表示一组测试数据 每行一开始,两个空格隔 ...