美文网首页
Oracle之约束

Oracle之约束

作者: 产品小正 | 来源:发表于2017-10-18 16:21 被阅读0次

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

    创建格式:在创建表时规定约束(在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是删除数据内容。

    相关文章

      网友评论

          本文标题:Oracle之约束

          本文链接:https://www.haomeiwen.com/subject/dhvduxtx.html