Sql--约束
2021/11/20 19:11:37
本文主要是介绍Sql--约束,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
约束
- 一、概念
- 二、分类
- 三、非空约束
- 四、唯一约束
- 五、主键约束
- 六、默认约束
- 七、外键约束
- 7.1外键概念
- 7.2外键语法
- 八、约束练习
- 九、总结
一、概念
- 约束是作用于表中列上的规则,用于限制加入表的数据
例如:我们可以给id列加约束,让其值不能重复,不能为null值。 - 约束的存在保证了数据库中数据的正确性、有效性和完整性
添加约束可以在添加数据的时候就限制不正确的数据,年龄是3000,数学成绩是-5分这样无效的数据,继而保障数据的完整性。
二、分类
- 非空约束: 关键字是 NOT NULL
保证列中所有的数据不能有null值。 - 唯一约束:关键字是 UNIQUE
保证列中所有数据各不相同。 - 主键约束: 关键字是 PRIMARY KEY
主键是一行数据的唯一标识,要求非空且唯一。一般我们都会给没张表添加一个主键列用来唯一标识数据。 - 默认约束: 关键字是 DEFAULT
保存数据时,未指定值则采用默认值。 - 外键约束: 关键字是 FOREIGN KEY
外键用来让两个表的数据之间建立链接,保证数据的一致性和完整性。
三、非空约束
- 概念:非空约束用于保证列中所有数据不能有NULL值
- 语法:
- 添加约束
-- 创建表时添加非空约束 CREATE TABLE 表名( 列名 数据类型 NOT NULL, … );
-- 建完表后添加非空约束 ALTER TABLE 表名 MODIFY 字段名 数据类型 NOT NULL;
2.删除约束
ALTER TABLE 表名 MODIFY 字段名 数据类型;
四、唯一约束
- 概念:唯一约束用于保证列中所有数据各不相同
- 语法:
1.添加约束
-- 创建表时添加唯一约束 CREATE TABLE 表名( 列名 数据类型 UNIQUE [AUTO_INCREMENT], -- AUTO_INCREMENT: 当不指定值时自动增长 … ); CREATE TABLE 表名( 列名 数据类型, … [CONSTRAINT] [约束名称] UNIQUE(列名) );
-- 建完表后添加唯一约束 ALTER TABLE 表名 MODIFY 字段名 数据类型 UNIQUE;
2.删除约束
ALTER TABLE 表名 DROP INDEX 字段名;
五、主键约束
- 概念:主键是一行数据的唯一标识,要求非空且唯一
一张表只能有一个主键 - 语法:
1.添加约束
-- 创建表时添加主键约束 CREATE TABLE 表名( 列名 数据类型 PRIMARY KEY [AUTO_INCREMENT], … ); CREATE TABLE 表名( 列名 数据类型, [CONSTRAINT] [约束名称] PRIMARY KEY(列名) );
-- 建完表后添加主键约束 ALTER TABLE 表名 ADD PRIMARY KEY(字段名);
2.删除约束
ALTER TABLE 表名 DROP PRIMARY KEY;
六、默认约束
- 概念:保存数据时,未指定值则采用默认值
- 语法:
1.添加约束
-- 创建表时添加默认约束 CREATE TABLE 表名( 列名 数据类型 DEFAULT 默认值, … );
-- 建完表后添加默认约束 ALTER TABLE 表名 ALTER 列名 SET DEFAULT 默认值;
2.删除约束
ALTER TABLE 表名 ALTER 列名 DROP DEFAULT;
七、外键约束
7.1外键概念
- 概念:外键用来让两个表的数据之间建立链接,保证数据的一致性和完整性。
员工表中的dep_id字段是部门表的id字段关联,也就是说1号学生张三属于1号部门研发部的员工。现在我要删除1号部门,就会出现错误的数据(员工表中属于1号部门的数据)。而我们上面说的两张表的关系只是我们认为它们有关系,此时需要通过外键让这两张表产生数据库层面的关系,这样你要删除部门表中的1号部门的数据将无法删除。
7.2外键语法
- 添加约束
-- 创建表时添加外键约束 CREATE TABLE 表名( 列名 数据类型, … [CONSTRAINT] [外键名称] FOREIGN KEY(外键列名) REFERENCES 主表(主表列名) );
-- 建完表后添加外键约束 ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段名称) REFERENCES 主表名称(主表列名称);
- 删除约束
ALTER TABLE 表名 DROP FOREIGN KEY 外键名称;
八、约束练习
- 创建员工表和部门表 添加外键约束
-- 删除表 DROP TABLE IF EXISTS emp; DROP TABLE IF EXISTS dept; -- 部门表 CREATE TABLE dept( id int primary key auto_increment, dep_name varchar(20), addr varchar(20) ); -- 员工表 CREATE TABLE emp( id int primary key auto_increment, name varchar(20), age int, dep_id int, -- 添加外键 dep_id,关联 dept 表的id主键 CONSTRAINT fk_emp_dept FOREIGN KEY(dep_id) REFERENCES dept(id) );
九、总结
这篇关于Sql--约束的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-02Java管理系统项目实战入门教程
- 2024-11-02Java监控系统项目实战教程
- 2024-11-02Java就业项目项目实战:从入门到初级工程师的必备技能
- 2024-11-02Java全端项目实战入门教程
- 2024-11-02Java全栈项目实战:从入门到初级应用
- 2024-11-02Java日志系统项目实战:初学者完全指南
- 2024-11-02Java微服务系统项目实战入门教程
- 2024-11-02Java微服务项目实战:新手入门指南
- 2024-11-02Java项目实战:新手入门教程
- 2024-11-02Java小程序项目实战:从入门到简单应用