MySQL中的完整性约束条件(主键、外键、唯一、非空)
数据库的完整性约束用来防止对数据的意外破坏,来保证数据的安全性和一致性。
主键
1.创建表时候指定主键
创建表user(id, username, age),并且id字段非空自增。
CREATE TABLE user(
id BIGINT(20) NOT NULL AUTO_INCREMENT
,username VARCHAR(16) NOT NULL
,age TINYINT
,PRIMARY KEY(id)
);
给数据库插入3条字段。

2.修改表中字段为主键
创建表user1(id, username),不设置主键,通过修改设置主键。
CREATE TABLE user1(
id BIGINT(20)
,username VARCHAR(16) NOT NULL
);
ALTER TABLE user1
ADD PRIMARY KEY(id)
,MODIFY id BIGINT(20) AUTO_INCREMENT;
通过SHOW INDEX FROM user1查看表user1的主键,可以看到有一个名字为PRIMARY的主键索引。

3.删除主键
删除表user1中的主键,如果主键为自增,那么还需要将自增去掉。
ALTER TABLE user1
DROP PRIMARY KEY
,MODIFY id BIGINT(20);
外键
外键用来指定参照完整性约束,被指定为外键的列必需要有索引,外键参考列必需为另一个表的主键。
1.创建表的时候指定外键
创建表article(id, u_id, article_name),u_id为该表的外键,引用user表中的id。
CREATE TABLE article(
id BIGINT(20) NOT NULL AUTO_INCREMENT
,u_id BIGINT(20) NOT NULL
,article_name VARCHAR(16) NOT NULL
,PRIMARY KEY(id)
,CONSTRAINT fk_user_article_uid FOREIGN KEY (u_id) REFERENCES user(id)
);
通过SHOW INDEX FROM article查看索引,可以看到该表中有两个索引。

2.修改表时添加外键约束
修改的时候表中如果有记录就会出错。
ALTER TABLE article
ADD CONSTRAINT fk_user_article_uid FOREIGN KEY(u_id) REFERENCES user(id);
添加了外键之后,再插入不存在user的id值的u_id字段就会出错。
3.删除外键
ALTER TABLE article
DROP FOREIGN KEY fk_user_article_uid;
通过SHOW INDEX FROM article可以看到,虽然外键被删除,但是之前设置为外键的列依然有索引。

这时再进行插入操作,插入在user表中不存在的u_id值,这时可以成功地进行插入。
INSERT INTO article(u_id, article_name)
VALUES (4, 'article4');
唯一
1.创建表的时候创建唯一约束条件
第一种方法,这种方法不能指定唯一索引的名字。
CREATE TABLE test1(
id BIGINT(20) NOT NULL AUTO_INCREMENT
,test1 INT UNIQUE KEY
,PRIMARY KEY(id)
);
查看索引,可以看到唯一索引的名字与字段名相同。

如果插入相同的test1,就会报错。
第二种方法,可以制定唯一索引的名字
CREATE TABLE test1(
id BIGINT(20) NOT NULL AUTO_INCREMENT
,test INT
,PRIMARY KEY(id)
,UNIQUE KEY uk_test(test)
);
通过查看索引可以看到,非空索引的名称是设定的名称。

2.修改表时添加
ALTER TABLE test1
ADD UNIQUE uk_test(test);
3.删除
ALTER TABLE test1
DROP INDEX uk_test;
非空
1.创建表的时候指定
CREATE TABLE test(
id BIGINT(20) NOT NULL AUTO_INCREMENT
,test1 INT NOT NULL
,PRIMARY KEY(id)
);
2.修改删除
删除非空
ALTER TABLE test
MODIFY test1 INT;
添加非空
ALTER TABLE test
MODIFY test1 INT NOT NULL;
总结
上述的四种约束性添加中,主键、外键、唯一在创建时就直接建立了该列的索引,非空是与索引无关的,不过非空字段也是可以建立索引的。
MySQL中的完整性约束条件(主键、外键、唯一、非空)的更多相关文章
- EF中主表和附表一起提交的话,如果主附表的主键外键已经设定。
EF中主表和附表一起提交的话,如果主附表的主键外键已经设定,如果新增同时新增主表和附表的记录,那么在EF同时提交时,不需要人为的设定附表的主表的主键值,EF会自动为附表添加外键值.
- 通过 jdbc 分析数据库中的表结构和主键外键
文章转自:http://ivan4126.blog.163.com/blog/static/20949109220137753214811/ 在某项目中用到了 hibernate ,大家都知道 hib ...
- java面试一日一题:mysql中的自增主键
问题:请讲下mysql中的自增主键 分析:该问题主要考察对mysql中自增主键的掌握,使用场景及如何设置 回答要点: 主要从以下几点去考虑 1.什么自增主键 2.使用场景是什么: 3.innodb_a ...
- Sql Server 主键 外键约束
主键约束 表通常具有包含唯一标识表中每一行的值的一列或一组列. 这样的一列或多列称为表的主键 (PK),用于强制表的实体完整性. 由于主键约束可保证数据的唯一性,因此经常对标识列定义这种约束. 如果为 ...
- 第15课-数据库开发及ado.net-数据库介绍,主键,外键,启动数据库,数据库身份验证方式,建表,分离数据库
第15课-数据库开发及ado.net 数据库介绍,主键,外键,启动数据库,数据库身份验证方式,建表,分离数据库 1. 学习方法 2. 多涨见识 3. 比自己强的人一起,学习更强:比自己更聪明的人 ...
- 关系型数据库——主键&外键的
一.什么是主键.外键: 关系型数据库中的一条记录中有若干个属性,若其中某一个属性组(注意是组)能唯一标识一条记录,该属性组就可以成为一个主键 比如 学生表(学号,姓名,性别,班级) 其中每个学 ...
- PowerDesigner中CDM和PDM如何定义外键关系
有A.B两张表(实体),各自有id作为主键,两表是一一对应关系.但略有不同: A表一条记录可以对应0或1条B表记录,B表一条记录必须对应唯一条A表记录. 这样的关系如何在CDM或PDM中定义? 在最后 ...
- Django笔记&教程 4-3 模型(models)主键外键
Django 自学笔记兼学习教程第4章第3节--模型(models)主键外键 点击查看教程总目录 参考:https://docs.djangoproject.com/en/2.2/ref/models ...
- Mysql主键外键操作
外键: ·一对多 ·多对多 ·一对一 ·修改表 ·复制表 主键: rimary key auto_increment(primary key是主键通常和auto_increment自动增加混合 ...
随机推荐
- QT第一天学习
sudo apt-get install libqt4-dev回顾: 面向对象方法: 封装.继承.多态 封装:类 数据和操作 实现了信息隐藏 public: 类的内部 类的外部 private: pr ...
- Coding 代码管理快速入门
当项目创建好了之后,我们该如何上传代码到 coding 上呢?Coding 网站使用“ Git 仓库”(类似 github )来管理代码.其操作原理在于:利用 git 服务,将本地的项目目录下的文件同 ...
- 配置FMS发布/HDS/HLS流
一.前言 安装完FMS4.5以后就有了apache2.2,由于在FMS安装目录里面,他是对外面已经安装的是没有影响的,默认情况向, FMS监听80端口接收traffic然后传递给Apache的8134 ...
- RabbitMQ确认机制问题处理
现象: 手动在后台创建两个消息反馈队列 代码中监听到消息队列后,对消息进行处理并确认,代码为: 运行代码后,消息未从队列扔出去. 原因及解决方案:后台手动创建队列后,在监听消息中又对队列进行声明创建, ...
- linux 中用python实现终端命令行命令
在python代码中实现和在终端中输入的命令行一样的效果,以命令(audacious -p &)为例,该代码实现用audacious在后台播放音乐的功能,当然前提是安装了audacious. ...
- 在C++中反射调用.NET(三)
在.NET与C++之间传输集合数据 上一篇<在C++中反射调用.NET(二)>中,我们尝试了反射调用一个返回DTO对象的.NET方法,今天来看看如何在.NET与C++之间传输集合数据. 使 ...
- SQL中如何使用EXISTS替代IN
原创作品,可以转载,但是请标注出处地址http://www.cnblogs.com/V1haoge/p/6385312.html 我们在程序中一般在做SQL优化的时候讲究使用EXISTS带替代IN的做 ...
- indexOf()--数组去重
@(JavaScript) 数组去重方法有多中,这里列举出自己认为比较容易理解的方法. 思路: 创建一个新的空数组,用来存放去重后的新数组. 利用for循环循环遍历需要去重的数组. 利用indexOf ...
- SpringMVC:学习笔记(2)——RequestMapping及请求映射
SpringMVC--RequestMapping及请求映射 @RequestMapping 说明 Spring MVC 使用 @RequestMapping 注解为控制器指定可以处理哪些 URL 请 ...
- Unity起步-1.1下载和安装Unity
1.1.下载和安装Unity 1.1.1 选取版本 首先找到Unity官方网站https://store.unity.com/cn,如果要下载最新版本,可以选择"立即下载".不过我 ...