美文网首页
SQL server 约束

SQL server 约束

作者: Demons_96 | 来源:发表于2016-11-22 19:35 被阅读78次

1、 创建院系表department,包含院系编号dno,院系名dname,其中dno为主键,且院系名不能为空。

create database mydb;
create table department(
    dno tinyint,
    dname varchar(20) not null,
    primary key(dno)
);

2、在院系表中插入两行数据

dno dname
1 计算机
2 外语
insert into department
values(1,'计算机');
insert into department
values(2,'外语');

3、创建教师表teacher,包含教师编号tno 主键,教师姓名tname 非空,教工身份证号 tid 唯一,教师性别gender,教工年龄 age,所属院系编号 deptid。

create table teacher(
    tno smallint primary key,
    tname varchar(20) not null,
    tid int unique,
    gender varchar(4),
    age tinyint,
    deptid tinyint,
);

4、在表teacher的列gender上增加检查约束,性别值只能取 男 或女。

alter table teacher
add  check(gender='男'or gender='女');

5、在表teacher的列age上增加检查约束,年龄介于 1~120。

alter table teacher
add  check(age between 1 and 120);

6、在表teacher的列deptid上增加外键约束,引用department表的dno列

alter table teacher
add foreign key(deptid) references department(dno);

7、在教师表teacher插入如下数据

tno tname tid gender age deptid
101 张潇 1111111 30 1
102 李大明 222222 40 2
insert into teacher
values(101,'张潇',1111111,'男',30,1);
insert into teacher
values(102,'李大明',222222,'女',40,2);

8、查询教师表teacher上的约束

exec sp_helpconstraint teacher;

9、删除教师表teacher上的外键约束

alter table teacher
drop constraint FK__teacher__deptid__08162EEB;

10、在教师表teacher上增加外键约束,当院系表修改主键列值时级联更新教师表,当院系表删除数据时将教师表中对应教师的所属院系编号置成null

alter table teacher
add foreign key(deptid) references department(dno)
on delete casecade on updata casecade;

11、将院系表中dno为1的院系编号修改为1001,删除院系表中院系编号为2的院系信息。观察教师表数据变化。

相关文章

  • sql中表级约束和列级约束

    sql中表级约束和列级约束,在SQL SERVER中, (1) 对于基本表的约束分为列约束和表约束 约束是限制用户...

  • SQL server 约束

    1、 创建院系表department,包含院系编号dno,院系名dname,其中dno为主键,且院系名不能为空。 ...

  • SQL Server 约束的管理

    约束是一种限制。通过在列级或表级设置约束,确保数据符合某种数据完整性规则。 约束的类型 域约束:域约束处理一个或多...

  • SQL 中的约束语句

    数据库:SQL Server 通用语法 1. 唯一性约束 UNIQUE 创建 删除 2. 主键约束 创建 删除 3...

  • SQL Sever 数据库之约束

    数据库的约束 一、创建、修改和删除约束 约束是SQL Server提供的自动强制数据完整性的一种方式,通过定义列的...

  • SQL Server on Ubuntu

    安装SQL Server(Install SQL Server) 1. 安装SQL Server 官网安...

  • SQL Server中有5种约束:

    主键约束(Primary Key Constraint)、默认约束(Default Constraint)、检查约...

  • 在SQL Server上创建约束

    在SQL Server上创建约束,防止两个字段同时重复, //shop为库名;DDHG_ServiceInfo为表...

  • SQL Server数据库高级进阶之索引优化实战演练

    一、SQL Server索引优化本质 二、SQL Server索引存储机制 三、SQL Server索引类型分类 ...

  • SQL

    SQL Server Management Studio SQL Server Management Studio...

网友评论

      本文标题:SQL server 约束

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