day 7-14 数据库完整性约束
一. 介绍
约束条件与数据类型的宽度一样,都是可选参数
作用:用于保证数据的完整性和一致性
主要分为:
PRIMARY KEY 标示该字段为表的主键,可以唯一的标示记录
FOREIGN KEY 标示该字段为该表的外键
NOT NULL 标示该字段不能为空
UNIQUE KEY 标示该字段的值是唯一的
AUTO_INCREMENT 标示该字段是自增长类型(数据类型为整数且是主键)
DEFAULT 为对应的字段设置默认值 UNSIGNED 无符号
ZEROFILL 使用0填充
使用方法及说明
#创建一个班级,班级的id是主键且是自增长类型的,班级的名称不能为空 create table class(
id int(4) primary key auto_increment ,
name char(20) not null
);
insert into class (name) values("中学三年二班"); #插入一条记录
# 创建一个学生表,id为主键,自增长,姓名不能为空,性别默认男,班级编号不能为空,班级编号的外键是class表中的id,分数是无符号类型.(0-255) create table student(
id int primary key auto_increment,
name char(6) not null,
sex enum("男","女") default "男",
class_id int(6) not null,
foreign key(class_id) references class(id),
score int(3) unsigned
); insert into student (name,sex,class_id,score)values("jack","男",1,75);
外键语法:
foreign key(要引用外键的字段) references 被引用的表名(被引用的表字段);
注意:
如果一个字段未设置not null,插入数据的时候,如果不给该字段传值,则默认值为NULL,如果设NOT NULL,则该字段不能为空,否则报错
二. not null 和default
是否可空,null表示空,非字符串
not null - 不可空
null - 可空
default默认值,创建列时可以指定默认值,当插入数据时如果未主动设置,则自动添加默认值
create table tb1(id int not null defalut 2 ,num int not null)
三. unique唯一性约束
单列唯一,设置某一个字段的唯一性.
-----1.单列唯一---------
create table t2(
id int not null unique,
name char(10)
);
insert into t2 values(1,'jack');
insert into t2 values(1,'lucy');
#上面创建表的时候把id设置了唯一约束。那么在插入id=1,就会出错了
联合唯一,设置多个字段组成在一起是唯一的.
create table t20(id int not null unique auto_increment,host char(15),port int,unique(host,port)); #设置host和port字段联合唯一 insert into t23(host,port) values("172.16.0.253",1990);
insert into t23(host,port) values("172.16.0.253",1991);
insert into t23(host,port) values("172.16.0.252",1990); # 2个字段合在一起是唯一的.
四. primary key(主键约束)
primary key字段的值不为空且唯一,一张表中可以做单列主键和复合主键(多列主键),但是一张表中只能有一个主键.
create table t25(id int primary key auto_increment,name char(6),age int);
insert into t25(name,age) values("jack",18);
select * from t25;
+----+------+------+
| id | name | age |
+----+------+------+
| 1 | jack | 18 |
+----+------+------+ #id作为自增长的主键
单列主键
create table t24(
name char(10) not null,
host char(15),
port int,
primary key(host,port)
);
insert into t24 values("mysql","172.168.0.253",3306);
insert into t24 values("ftp","172.168.0.253",21);
insert into t24 values("mysql","172.168.0.253",3306); #插入相同的会报错
#用法和unique的联合唯一差不多
多列主键
五. auto_increment(自增长约束)
auto_increment有2个属性:
1.auto_increment_increment 步长
2.auto_increment_offset 起始偏移量
---------------------未设置步长和起始偏移量------------------------------
create table t26(id int primary key auto_increment,name char(6));
insert into t26(name) values("IT"),("HR"),("SALER");
SELECT * FROM T26;
+----+-------+
| id | name |
+----+-------+
| 1 | IT |
| 2 | HR |
| 3 | SALER |
+----+-------+ --------------------------设置起始步长为100---------------------------------------
create table t27(id int primary key auto_increment,name char(6))auto_increment=100;
insert into t27(name) values("IT"),("HR"),("SALER");
SELECT * FROM T27;
+-----+-------+
| id | name |
+-----+-------+
| 100 | IT |
| 101 | HR |
| 102 | SALER |
+-----+-------+
------------------------------设置步长和起始偏移量------------------------------------
set session auto_increment_increment =1000;
还是在27这张表插入一个新的值
insert into t27 (name) values("HHH"); #HHH的编号已经是1001了
select * from t27;
+------+-------+
| id | name |
+------+-------+
| 100 | IT |
| 101 | HR |
| 102 | SALER |
| 1001 | HHH |
+------+-------+ #设置偏移量
set session auto_increment_offset =2;
insert into t27(name) values ("RRR"),("PPP"),("QQQ");
select * from t27;
+------+-------+
| id | name |
+------+-------+
| 100 | IT |
| 101 | HR |
| 102 | SALER |
| 1001 | HHH |
| 2002 | RRR |
| 3002 | PPP |
| 4002 | QQQ |
+------+-------+ #每增加一个值,步长都会增加1000,偏移量是2
注意:offset的值不能大于increment的值,否则无效.
六. 外键约束(foreign key)
员工表里有三个字段:姓名,性别,部门.现在公司有员工20000人,3个部门.这意味着部门名称会有大量的重复数据.这时候可以使用外键来解决这个问题.先建立一个部门表.再建立员工表,把员工表中的部门ID设置为外键,来自部门表中的部门ID即可.
开始建表,注意:一定要先建立被关联的外键表(部门表).在建立(员工表),被关联的字段必须是唯一的,要先给被关联的表插入记录.
create table dep(id int primary key auto_increment,name char(15));
insert into dep(name) values("HR"),("IT"),("SALE");
mysql> SELECT * FROM DEP;
+----+------+
| id | name |
+----+------+
| 1 | HR |
| 2 | IT |
| 3 | SALE |
+----+------+
create table emp(id int primary key auto_increment,name char(6) not null,
sex enum("male","female"),depart_id int); insert into emp(name,sex,depart_id) values
("jack","male",2),
("lucy","female",1),
("lili","female",3),
("hanmeimei","female",1),
("lilei","male",2),
("erya","female",3); select * from emp;
+----+--------+--------+-----------+
| id | name | sex | depart_id |
+----+--------+--------+-----------+
| 1 | jack | male | 2 |
| 2 | lucy | female | 1 |
| 3 | lili | female | 3 |
| 4 | hanmei | female | 1 |
| 5 | lilei | male | 2 |
| 6 | erya | female | 3 |
+----+--------+--------+-----------+ show create table emp\G;
*************************** 1. row ***************************
Table: emp
Create Table: CREATE TABLE `emp` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` char(6) NOT NULL,
`sex` enum('male','female') DEFAULT NULL,
`depart_id` int(11) DEFAULT NULL,
PRIMARY KEY (`id`),
KEY `depart_id` (`depart_id`),
CONSTRAINT `emp_ibfk_1` FOREIGN KEY (`depart_id`) REFERENCES `dep` (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8
1 row in set (0.00 sec)
外键约束(foreign key
上面建立的表,有一个坏处,如果部门的id发生了变化,员工表中的部门id并不会有所改变.如果部门解散了.员工信息也不会删除.
drop table emp;
create table emp(id int primary key auto_increment,
name char(6) not null,
sex enum("male","female"),
depart_id int,foreign key (depart_id) references dep(id)
on delete cascade
on update cascade); #加上这两个语句,在部门ID发生变化时,员工表中的部门id也会跟着辩护
update table dep id=101 where id=1; #修改部门1的id
select * from emp; +----+--------+--------+-----------+
| id | name | sex | depart_id |
+----+--------+--------+-----------+
| 1 | jack | male | 2 |
| 2 | lucy | female | 101 |
| 3 | lili | female | 3 |
| 4 | hanmei | female | 101 |
| 5 | lilei | male | 2 |
| 6 | erya | female | 3 |
+----+--------+--------+-----------+
外键约束优化版
day 7-14 数据库完整性约束的更多相关文章
- Python标准库14 数据库 (sqlite3)
作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! Python自带一个轻量级的关系型数据库SQLite.这一数据库使用SQL语言.S ...
- 【循序渐进学Python】14.数据库的支持
纯文本只能够实现一些简单有限的功能.如果想要实现自动序列化,也可以使用 shelve 模块和 pickle 模块来实现.但是,如果想要自动的实现数据并发访问,以及更标准,更通用的数据库(databas ...
- MySQL数据库----完整性约束
一.介绍 约束条件与数据类型的宽度一样,都是可选参数 作用:用于保证数据的完整性和一致性主要分为: PRIMARY KEY (PK) 标识该字段为该表的主键,可以唯一的标识记录 FOREIGN KEY ...
- 08-Mysql数据库----完整性约束
总结: 1,not null 不能插入空,不设置可空 2,unique 单列唯一 create table department(name char(10) unique); ...
- 数据库及SQL----常用知识点总结
数据库也是计算机类笔试面试中不可避免会遇到的考点,尤其是银行和部分传统软件类公司.这里根据整理的资料,对数据库的相关知识也做个总结吧.希望学过数据库但长时间不用的同学根据这些知识能够回忆和重拾,没学过 ...
- Oracle数据库 —— DDL
时间:2016-10-5 14:55 逆风的方向更适合飞翔我不怕千万人阻挡只怕自己投降 --------------------------------------- 一.表的创建与管理1.表的基本操 ...
- asp.net core 使用EF7 Code First 创建数据库,同时使用命令创建数据库
1.首先下载vs2015的Asp.Net Core(RC2)的插件工具(https://www.microsoft.com/net/core#windows)2.创建一个asp.net Core的项目 ...
- MySql数据库的基本原理及指令
1.什么是数据库 数据库就是存储数据的仓库,其本质是一个文件系统,数据按照特定的格式将数据存储起来,用户可以通过SQL对数据库中的数据进行增加,修改,删除及查询操作. 2.简介 MySQL是一个开放源 ...
- Python 经典面试题汇总之数据库篇
数据库和缓存 1.列举常见的关系型数据库和非关系型都有那些? 关系型数据库(需要有表结构) mysql.oracle.splserver.postgresql.db2.sybase 非关系型数据库(是 ...
随机推荐
- JSX格式化代码,你值得拥有!
ext install prettier-vscode https://segmentfault.com/q/1010000014822745
- docker1.13.1的安装与卸载及mysql5.5安装实例
docker中国官方地址:https://www.docker-cn.com/ 您可以使用以下命令直接从该镜像加速地址进行拉取: $ docker pull registry.docker-cn.co ...
- 设置ansible与windows连通性
1.确认powershell的版本,必须是3.0以上 $PSVersionTable.PSVersion 2.确认winrm是否开启命令:winrm quickconfig 3.在windows配置w ...
- centos7下安装docker(21docker swarm集群创建)
创建swarm集群: 实验环境:盗图 swarm-manager是manager node,swarm-worker1和swarm-worker2是worker node. 所有节点的docker版本 ...
- <转> mysql处理高并发,防止库存超卖
先来就库存超卖的问题作描述:一般电子商务网站都会遇到如团购.秒杀.特价之类的活动,而这样的活动有一个共同的特点就是访问量激增.上千甚至上万人抢购 一个商品.然而,作为活动商品,库存肯定是很有限的,如何 ...
- [SHOI2015]超能粒子炮·改
嘟嘟嘟 先看了一遍lucas,还是只能拿50分(似乎已经满足了). 正解当然还是看某个大佬的啦. 我们要求的就是 \[f(n, k) = \sum _ {i = 0} ^ {k} C _ {n} ^ ...
- Python:Day18 os模块、logging模块、正则表达式
迭代器 满足迭代器协议: 1.内部有next方法 2.内部有iter()方法 os模块 import os print(os.getcwd()) #C:\Users\Lowry\PycharmProj ...
- [LeetCode]最大系列(最大正方形221,最大加号标志764)
221. 最大正方形 题目描述: 在一个由 0 和 1 组成的二维矩阵内,找到只包含 1 的最大正方形,并返回其面积. 示例: 输入: 1 0 1 0 0 1 0 1 1 1 1 1 1 1 1 1 ...
- 1.java的基础和数据类型
一.学习要求1.听课一定要全神贯注2.课堂笔记,一定要自己总结,而且要有很严谨的逻辑关系.提纲很重要3.作业不折不扣的完成,并且多完成4.阶段项目一定要独立完成5.每天早上由一位同学来进行早分享,内容 ...
- Ubuntu下的 PPPoE 拨号上网方法
1. 配置 pppoe $ sudo pppoeconf 2. 联网 $ sudo pon dsl-provider 3. 断网 $ sudo poff 4. 查看日志 $ plog 5. 查看接口信 ...