当前位置: 首页 > news >正文

asp sqlserver做网站哪一家好

asp sqlserver做网站,哪一家好,建设部招标网 官方网站,建设银行网站为什么进不去一、概述 概念:约束是作用于表中字段上的规则,用于限制存储在表中的数据。 目的:保证数据库中数据的正确、有效性和完整性。 分类: 注意:约束是作用于表中字段上的,可以在创建表/修改表的时候添加约束。 二…

一、概述

概念:约束是作用于表中字段上的规则,用于限制存储在表中的数据。

目的:保证数据库中数据的正确、有效性和完整性。

分类:
在这里插入图片描述
注意:约束是作用于表中字段上的,可以在创建表/修改表的时候添加约束。

二、约束演示

案例需求: 根据需求,完成表结构的创建。需求如下:
在这里插入图片描述

CREATE TABLE tb_user(id     int AUTO_INCREMENT PRIMARY KEY COMMENT 'ID唯一标识',name   varchar(10) NOT NULL UNIQUE COMMENT '姓名',age    int check (age > 0 && age <= 120) COMMENT '年龄',status char(1) default '1' COMMENT '状态',gender char(1) COMMENT '性别'
);

在为字段添加约束时,我们只需要在字段之后加上约束的关键字即可,需要关注其语法。我们执行上面的 SQL 把表结构创建完成,然后接下来,就可以通过一组数据进行测试,从而验证一下,约束是否可以生效。

insert into tb_user(name,age,status,gender) values ('Tom1',19,'1','男'),('Tom2',25,'0','男');
insert into tb_user(name,age,status,gender) values ('Tom3',19,'1','男');
insert into tb_user(name,age,status,gender) values (null,19,'1','男');
insert into tb_user(name,age,status,gender) values ('Tom3',19,'1','男');
insert into tb_user(name,age,status,gender) values ('Tom4',80,'1','男');
insert into tb_user(name,age,status,gender) values ('Tom5',-1,'1','男');
insert into tb_user(name,age,status,gender) values ('Tom5',121,'1','男');
insert into tb_user(name,age,gender) values ('Tom5',120,'男');

三、外键约束

1. 介绍

外键:用来让两张表的数据之间建立连接,从而保证数据的一致性和完整性。

2. 语法

2.1 添加外键

CREATE TABLE 表名(字段名 数据类型,...[CONSTRAINT] [外键名称] FOREIGN KEY (外键字段名) REFERENCES 主表 (主表列名)
);

案例:
为 emp 表的 dept_id 字段添加外键约束,关联 dept 表的主键 id。

alter table emp add constraint fk_emp_dept_id foreign key (dept_id) references dept(id);

添加了外键约束之后,我们再到 dept 表(父表)删除 id 为 1 的记录,然后看一下会发生什么现象。 此时将会报错,不能删除或更新父表记录,因为存在外键约束。

2.2 删除外键

ALTER TABLE 表名 DROP FOREIGN KEY 外键名称; 

案例:
删除emp表的外键fk_emp_dept_id。

alter table emp drop foreign key fk_emp_dept_id;

3. 删除/更新行为

添加了外键之后,再删除父表数据时产生的约束行为,我们就称为删除/更新行为。具体的删除/更新行为有以下几种:
在这里插入图片描述
具体语法为:

ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段) REFERENCES 主表名 (主表字段名) ON UPDATE CASCADE ON DELETE CASCADE;

由于 NO ACTION 是默认行为,我们前面语法演示的时候,已经测试过了,就不再演示了,这里我们再演示其他的两种行为:CASCADE、SET NULL。

(1)CASCADE

alter table emp add constraint fk_emp_dept_id foreign key (dept_id) references dept(id) on update set null on delete set null ;

1️⃣修改父表 id 为1的记录,将 id 修改为 6
我们发现,原来在子表中 dept_id 值为 1 的记录,现在也变为 6 了,这就是cascade 级联的效果。
在一般的业务系统中,不会修改一张表的主键值。

2️⃣删除父表 id 为 6 的记录
我们发现,父表的数据删除成功了,但是子表中关联的记录也被级联删除了。

(2)SET NULL

alter table emp add constraint fk_emp_dept_id foreign key (dept_id) references dept(id) on update cascade on delete cascade ;

1️⃣我们发现父表的记录是可以正常的删除的,父表的数据删除之后,再打开子表 emp,我们发现子表 emp 的 dept_id 字段,原来 dept_id 为1的数据,现在都被置为 NULL 了。

http://www.yayakq.cn/news/91807/

相关文章:

  • 用xp做网站是否先搭建iis免费云服务器永久使用下载
  • 北京诚信建设网站前端后端哪个好找工作
  • 网站建设维护是做什么的html网页设计思路
  • 企业网站的形式西安网站建设专业公司
  • 怎么把网站变成免费的手机网站打开微信支付功能
  • 做网站保定html知识点整理
  • 做网站是怎么回事淘宝放单网站开发
  • 广州专业网站制作哪家专业seo关键词排名优化销售
  • 全面的苏州网站建设定州网站建设公司
  • 教育类网站建设方案邢台哪里做网站
  • 热水器网站建设 中企动力做网站毕设答辩问题
  • 孝感网站开发找优搏昌平网站建设浩森宇特
  • 南京汽车集团网站建设家装设计一般用什么软件
  • 折扣网站搭建常州网站建设 个人
  • 网站建设行业的趋势武陵天下网站开发
  • 如何侵入网站服务器西安网站设计师
  • 建设网站多少钱免费做章子的网站
  • 北镇网站建设企业app开发企业
  • 东莞企业网站搭建制作仿快递网站源码
  • 网站权重什么意思品牌网页设计公司
  • 谁有手机网站定兴做网站
  • 作文大全网站企业网站推广最有效的方法
  • 网站和微网站创意网页
  • 做视频资源网站有哪些app网站与普通网站的区别是什么
  • 网站推广公司电话本地南通网站建设
  • 宁波建网站哪家值得信赖网站建设 台州
  • 做外贸营销网站谷歌seo网站排名优化
  • 网站地图样本wordpress批量上传图片
  • 怎么做简易网站wordpress输入网址采集单个网页
  • 杭州 洛阳网站建设公司 网络服务免费网站自动跳转