Oracle之约束

约束用于限制加入表数据的类型,目的是保证数据的一致性和完整性

创建格式:在创建表时规定约束(在Create添加),也可以在创建之后添加(Alter table)。

约束类型:NOT NULL、UNIQUE、PRIMARY KEY、FOREIGN KEY、CHECK、DEFAULT。

非空约束 NOT NULL

非空约束就是限制必须为某个列提供值,不允许有空值的存在。

空值(NULL)是不存在的值,它既不是数字0也不是空字符串,而是不存在未知的情况,即:该列的所有值不能为空,但可以为空字符或者0。

create teable 表名(

    列名 类型(参数) not null,

    ...

);

或者

alter table 表名 modify 列名 not null;

结果:通过desc查看会发现Nullable那一列的Y消失,表示此列不能为空。且在插入数值的时候此列必须添加数值,否则会报错。

create table test1 (

BookNO number(4) not null,

BookName varchar2(20),

Author varchar2(10)

);

或者

alter table test1 modify Author not null;

取消非空约束使用alter方法:alter table test1 modify Author null; 设置test1的Author可以

唯一约束 UNIQUE

唯一性约束强调所在的列不允许有相同的值,但可以有多个Null。

其定义比主键约束弱,即他的列允许有空值(主键不允许有空值),唯一性约束的主要作用是保证在除主键外,其他列值得唯一性。

create teable 表名(

列名 类型(参数) unique,

...

);

或者

create teable 表名(

列名 类型(参数) Constraint 约束名 unique,

...

);

或者

create teable 表名(

列名1 类型(参数)

...

Constraint 约束名 unique(列名);

);

或者

alter table 表名 add constraint 约束名 unique(列名);

即:直接在列后面添加unique,

或在列后面添加 constraint 约束名 unique,

或在最后添加constraint 约束 unique(列名),

或者alter table 表名 add constraint 约束名 unique(列名);

建议使用的方法为alter和在最后添加最后添加constraint 约束 unique(列名)。

注:添加约束名的好处为:便于删除操作,在删除时需要通过约束名来完成操作。同时如果不添加约束名则系统会自动生成约束名,在表移动等操作时,约束名也会更改,会造成后期操作的麻烦。

create table test3(

MemNo number(4) not null,

QQ varchar2(20) unique

);

或者

create table test3_1(

MemNo number(4) not null,

QQ varchar2(20) Constraint QQ_UK unique

);

或者

create table test3_2(

MemNo number(4) not null,

QQ varchar2(20),

Constraint QQ_UK3_2 unique(QQ)

);

或者

alter table test3 add constraint QQ_UK2 unique(MemNO);

取消唯一性约束:alter table test3 drop constraint QQ_UK2;

主键约束PRIMARY KEY

主键约束唯一地标识了每一行记录(非空+唯一),在一个表中,最多只能有一个主键约束,主键约束既可以由一个列组成,也可以由两个或两个以上列组成(这种称联合主键)。

create teable 表名(

列名 类型(参数) primary key,

...

);

或者

create teable 表名(

列名 类型(参数) Constraint 自定义主键名 primary key,

...

);

或者

create teable 表名(

列名1 类型(参数),

...

constraint 自定义主键名 primary key (主键列名)

);

或者

alter table 表名 add constraint 自定义主键名 primary key(列名)

具体的方法和添加唯一约束相同,建议使用的方法为alter和在最后添加最后添加constraint 约束 unique(列名)。

create table test4(

stuno number(10) primary key,

stuname varchar2(8)

);

或者

create table test4_1(

stuno number(10) constraint test4_1_PK primary key,

stuname varchar2(8)

);

或者

create table test4_2(

stuno number(10),

stuname varchar2(8),

constraint test4_2_PK primary key(stuno)

);

或者

create table test4_3(

stuno number(10),

stuname varchar2(8)

);

或者

alter table test4_3 add constraint test4_3_PK primary key(stuno);

删除主键:alter table 表名 drop constraint 约束名

外键约束FOREIGN KEY

外键约束主要是在B表中的某一列受到A表的制约,B的那一列的值只能是A内的值,比如工资表的员工号必须受员工表的员工号限制一样,工资表不能有不存在的员工号。

一般外键约束会使用两个表进行关联,外键是指"当前表"引用"另一个表"的某一列或某几列。在另一个表中,被引用的列必须具有主键约束或者唯一性约束,不存在的数据不能出现在当前表的对应列中。一般情况下当删除被引用表中数据时,该数据也不能出现在外键列中,如果存在则删除失败。

create teable 表名(

列名 类型(参数) ,

...

constraint 自定义外键名称 foreign key(外键表列名) references 被引用表名(被引用列名)

);

alter table 表名 add constraint 自定义外键名称 foreign key (外键表列名) references 被引用表名;

create table test5(

stuno number(10),

age int,

constraint FK_test_5 foreign key (stuno) references test4_1(stuno)

);

或者

create table test5_1(

stuno number(10),

age int

);

或者

alter table test5_1 add constraint FK_test_5_1 foreign key (stuno) references test4_2(stuno);

删除外键约束:alter table test5_1 drop constraint FK_test_5_1;

条件约束 CHECK

check约束是为了让表中某字段值只能输入固定的值。

create teable 表名(

列名 类型(参数)  check (列名 in (选项1,选项2)),

...

);

或者

create teable 表名(

列名1 类型(参数),

...

constraint 约束名

);

或者

alter table 表名 add constraint 自定义主键名 check (列名 in (选项1,选项2));

create table test6(

stuno number(10),

sex char(2) check (sex in ('男','女'))

);

或者

create table test6_1(

stuno number(10),

sex char(2),

constraint check_test_6_1 check (sex in ('男','女'))

);

或者

create table test6_2(

stuno number(10),

sex char(2)

);

或者

alter table test6_2 add constraint check_test_6_2 check (sex in ('男','女'));

check设置数值范围:constraint check 表名 check (列名 between 小范围 and 大范围);

设置为大写:constraint check 表名 check (列名 = upper(列名));

取消 alter table test6_2 drop constraint check_test_6_2;

默认约束 DEFAULT

默认约束是设置列的默认值,即当插入一行时,若不给出该列的值,就用默认值代替。

create teable 表名(

列名 类型(参数) default '默认值',

...

);

或者

alter table 表名 modify 列名 default '默认值';

结果:在添加数据的时候,如果在设置有默认值的列没有添加数据则会把默认值添加进去。

create table test2 (

BookNO number(4) not null,

BookName varchar2(20),

Author varchar2(10) default 'me'

);

或者

alter table test2 modify BOOKNAME default 'you';

取消默认约束 alter table test2 modify BOOKNAME default null;

注:

add用于修改字段类型和长度的(即修改字段的属性)

modify修改表的数据结构。

update是修改数据内容的。

drop是删除数据内容。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,547评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,399评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,428评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,599评论 1 274
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,612评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,577评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,941评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,603评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,852评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,605评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,693评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,375评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,955评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,936评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,172评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,970评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,414评论 2 342

推荐阅读更多精彩内容