2024.1.24学习心得

命令建表和约束实例

TIP:可以给任一的约束起名。

例:

emp_id int constraint pk_emp_id_haha primary key(主键取名)

dept_id int constraint fk_dept_id_heihei foreign key references dept(dept_id)(外键取名)

在create table中最后一个字段建议不要写逗号(保持与Oracle相同的语法规定,提高代码的移植性)

 代码展示:

create table dept
(
    dept_id int primary key,
    dept_name nvarchar(100) not null,
    dept_address nvarchar(100)
)

create table emp
(
    emp_id int constraint pk_emp_id_haha primary key,
    emp_name nvarchar(20) not null,
    emp_sex nchar(1),
    dept_id int constraint fk_dept_id_heihei foreign key references dept(dept_id)
)

执行结果:

什么是约束?

定义:

        对一个表中的属性操作的限制叫约束。

分类:

主键约束(实体完整性,主键不能为空):

        不允许重复元素,避免了数据冗余。

外键约束(引用完整性):

        通过外键约束从语法上保证了本事物所关联的其他事物一定是存在的。

check约束:

        保证事物属性的取值在合法范围之内。

default约束:

        保证事物的属性一定会有一个值。

unique唯一约束(unique和not null可以组合使用):

        保证了事物属性的取值不允许重复,但允许其中有且仅有一列为空。

提问:unique键是否允许多列为空?

答:SQL Server仅允许一个unique列为空;Oracle允许多个unique列为空。

  • 15
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值