MySQL约束(创建表时的各种条件说明)


Posted in MySQL onJune 21, 2022

由于增删改了emp表中的记录,因此这里重新创建了一个脚本并使用

create database bjpowernnode;
use bjpowernode;
source C:\Users\Administrator\Desktop\bjpowernode.sql;

约束

1.什么是约束?

  • 约束就是表中的限制条件
  • 约束的关键字是:constraint

2. 约束的分类

  • 非空约束     not null
  • 唯一性约束   unique
  • 主键约束     primary key
  • 外键约束     foreign key
  • 检查约束     MySQL数据库不支持,Oracle数据库支持

1. not null(非空约束)

not null约束的字段,不能为null值,必须给具体的数据

创建表,给字段添加 非空约束【用户的邮箱地址不能为空】

drop table if exists t_user;
create table t_user(
        id int(10),
        name varchar(32) not null,
        email varchar (32)
);

MySQL约束(创建表时的各种条件说明)

MySQL约束(创建表时的各种条件说明)

2. unique(唯一性约束)

创建表,保证邮箱地址唯一

create table t_user(
id int(10),
name varchar(32) not null,
email varchar(128) unique
);

MySQL约束(创建表时的各种条件说明)

unique约束的字段不能重复,但是可以为null

MySQL约束(创建表时的各种条件说明)

以上的约束属于列级约束

表级约束:

 create table t_user(
     id int(10),
     name varchar(32),
     email varchar(128),
     unique(email)
 );

 1.使用表级约束给多个字段添加约束

 create table t_user(
     id int(10),
     name varchar(32),
     email varchar(128),
     unique(name,email)
);

2.表级约束可以给约束起名,以后通过这个名字来删除约束

   create table t_user(
       id int(10),
       name varchar(32),
       email varchar(128),
       constraint t_user_email_unique unique(email)
 );

MySQL约束(创建表时的各种条件说明)

MySQL约束(创建表时的各种条件说明)

MySQL约束(创建表时的各种条件说明)

not null 和unique可以联合使用

MySQL约束(创建表时的各种条件说明)

3. primary key (主键约束)

1.主键涉及到的术语:

  • 主键约束
  • 主键字段
  • 主键值

2.以上三者之间的关系:

  • 表中的某个字段添加主键约束之后,该字段称为主键字段
  • 主键字段中出现的每一个数据都被称为主键值

3.给某个字段添加主键约束以后,该字段不能重复,也不能为空

  • 主键约束效果和''not null unique'' 相同,但是本质不同,
  • 主键约束除了可以做到''not null unique''之外
  • 主键字段还会默认添加''索引-index''

4. 一张表应给有主键字段,如果没有,表示这张表是无效的

  • 主键值是当前行数据的唯一标识
  • 主键值是当前行数据的身份证号码
  • 即使表中的两行记录数据是完全相同的,
  • 但是由于主键值不同,就认为这是两行完全不同的字段

5.无论是单一主键还是复合主键,一张表的主键约束只能有一个

  • 给一个字段添加主键约束,被称为单一主键约束
  • 给多个字段联合添加主键约束,被称为复合主键

6.主键根据性质分类:

  • 自然主键:主键值是一个自然数,这个主键和当前的业务没有关系
  • 业务主键:主键值和当前业务紧密相关
  • 当业务发生改变的时候,主键值通成会受到影响,所以业务主键之用很少。

单一主键,列级约束

create table t_user(
    id int(10) primary key,
    name varchar(32)
);

MySQL约束(创建表时的各种条件说明)

单一主键,表极约束

 create table t_user(
     id int(10),
     name varchar(32),
     primary key(id)
);

MySQL约束(创建表时的各种条件说明)

复合主键:只能用表级约束

mysql> create table t_user(
    -> id int(10),
    -> name varchar(32),
    -> primary key(id,name)
    -> );

MySQL约束(创建表时的各种条件说明)

MySQL约束(创建表时的各种条件说明)

auto_increment:主键自增

MySQL数据管理系统中提供了一个自增的数字,专门用来自动生成主键值

主键值不需要用户维护,也不需要用户提供了,自动生成的,

这个自增的数字默认从1开始以1递增:1,2,3,4,....

mysql> create table t_user(
    -> id int(10) primary key auto_increment,
    -> name varchar(32)
    -> );

MySQL约束(创建表时的各种条件说明)

4. foreign key(外键约束)

1.外键约束涉及到的术语:

  • 外键约束
  • 外键值
  • 外键字段

2.以上三者之间的关系:

  • 某个字段添加外键约束以后称为外键字段
  • 外键字段中的每一个数据称为外键值

3.外键分为单一外键和复合外键

  • 单一外键:给一个字段添加外键约束
  • 复合外键:给多个字段添加外键约束

4.一张表中可以有多个外键字段

设计一个数据库表,用来存储学生和班级信息,给出两种解决方案:

学生信息和班级信息之间的关系:一个班级对应多个学生,这是典型的一对多的关系

在多的一方加外键

第一种设计方案:将学生信息和班级信息存储到一张表中

第二种设计方案:将学生信息和班级信息分开两张表存储,学生表+班级表

  • 学生表 t_student
sno(主键约束) sname classno(外键约束)
1 jack 100
2 lucy 100
3 kk 100
4 smith 200
5 frank 300
6 jhh 300
  • 班级表t_calss
cno(主键约束) cname
100 高三1班
200 高三2班
300 高三3班

为了保证t_student 表中的classno字段中的数据必须来自于t_class表中的cno字段中的数据,有必要给t_student表中的classno字段添加外键约束,classno称为外键字段,该字段中的值称为外键值。

注意:

1.外键值可以为空

2.外键字段必须得引用这张表中的主键吗?

  • 外键字段引用一张表的字段的时候,被引用的字段必须具备唯一性
  • 即具有unique约束,不一定非是主键

3.班级表为父表,学生表为子表

  • 应该先创建父表,再创建子表
  • 删除数据时,应该先删除子表中的数据,再删除父表中的数据
  • 插入数据时,应该先插入父表中的数据,再删除子表中的数据

MySQL约束(创建表时的各种条件说明)

DROP TABLE IF EXISTS t_student;
DROP TABLE IF EXISTS t_class;
 
 CREATE TABLE t_class(
 cno INT(3) PRIMARY KEY,
 cname VARCHAR(128) NOT NULL UNIQUE
 );
 
 CREATE TABLE t_student(
 sno INT(3) PRIMARY KEY,
 sname VARCHAR(32) NOT NULL,
 classno INT(3),-- 外键
 CONSTRAINT t_student_class_fk FOREIGN KEY(classno) REFERENCES t_class(cno)
 );
 
 INSERT INTO t_class(cno,cname) VALUES(100,'高三1班');
 INSERT INTO t_class(cno,cname) VALUES(200,'高三2班');
 INSERT INTO t_class(cno,cname) VALUES(300,'高三3班');
 
 INSERT INTO t_student(sno,sname,classno) VALUES(1,'jack',100);
 INSERT INTO t_student(sno,sname,classno) VALUES(2,'lucy',100);
 INSERT INTO t_student(sno,sname,classno) VALUES(3,'hh',100);
 INSERT INTO t_student(sno,sname,classno) VALUES(4,'frank',200); 
 INSERT INTO t_student(sno,sname,classno) VALUES(5,'smith',300);
 INSERT INTO t_student(sno,sname,classno) VALUES(6,'jhh',300);
 
 SELECT * FROM t_student;
 SELECT * FROM t_class;
 
-- 添加失败,因为有外键约束 
 INSERT INTO t_student(sno,sname,classno) VALUES(8,'kk',500);

重点:典型的一对多关系,设计时在多的一方加外键

5. 级联更新与级联删除

在删除父表中的数据的时候,级联删除子表中的数据

在更新父表中的数据的时候,级联更新子表中的数据

以上的级联更新和级联删除谨慎使用,

因为级联操作会使数据数据改变或删除,数据是无价的。

语法:

  • 级联更新:on update cascase
  • 级联删除:on delete cascase

MySQL约束(创建表时的各种条件说明)

MySQL约束(创建表时的各种条件说明)

MySQL中对于有些约束的修改比较麻烦,所以应该先删除约束,再添加约束

删除外键约束:

alter table t_student drop foreign key t_student_class_fk

添加外键约束并级联更新:

alter table t_student add constraint t_student_class_fk foreign key(classno)
references t_class(no) on delete cascade;

添加外键约束并级联删除:

alter table t_student add constraint t_student_class_fk foreign key(classno)
references t_class(no) on update cascade;

级联删除

MySQL约束(创建表时的各种条件说明)

MySQL约束(创建表时的各种条件说明)

级联更新

MySQL约束(创建表时的各种条件说明)

MySQL约束(创建表时的各种条件说明)

以上为个人经验,希望能给大家一个参考,也希望大家多多支持三水点靠木。


Tags in this post...

MySQL 相关文章推荐
MySQL性能压力基准测试工具sysbench的使用简介
Apr 21 MySQL
详解MySQL 联合查询优化机制
May 10 MySQL
MySQL 分页查询的优化技巧
May 12 MySQL
MySQL中distinct和count(*)的使用方法比较
May 26 MySQL
MySQL5.7并行复制原理及实现
Jun 03 MySQL
MYSQL 运算符总结
Nov 11 MySQL
Linux7.6二进制安装Mysql8.0.27详细操作步骤
Nov 27 MySQL
MySQL创建管理RANGE分区
Apr 13 MySQL
mysql实现将字符串字段转为数字排序或比大小
Jun 14 MySQL
MySQL聚簇索引和非聚簇索引的区别详情
Jun 14 MySQL
面试官问我Mysql的存储引擎了解多少
Aug 05 MySQL
MySQL数据库实验实现简单数据库应用系统设计
Jun 21 #MySQL
MySQL数据库表约束讲解
Jun 21 #MySQL
MySQL数据库实验之 触发器和存储过程
Jun 21 #MySQL
MySQL transaction事务安全示例讲解
Jun 21 #MySQL
MySQL详细讲解变量variables的用法
Jun 21 #MySQL
mysql sql常用语句大全
Jun 21 #MySQL
MySQL示例讲解数据库约束以及表的设计
Jun 16 #MySQL
You might like
php操作xml
2013/10/27 PHP
PHP数据对象PDO操作技巧小结
2016/09/27 PHP
PHP实现防盗链的方法分析
2017/07/25 PHP
PHP错误提示It is not safe to rely on the system……的解决方法
2019/03/25 PHP
JQUERY对单选框(radio)操作的小例子
2013/04/25 Javascript
IE浏览器中图片onload事件无效的解决方法
2014/04/29 Javascript
setinterval()与clearInterval()JS函数的调用方法
2015/01/21 Javascript
详解JavaScript的Date对象(制作简易钟表)
2020/04/07 Javascript
实例讲解js验证表单项是否为空的方法
2016/01/09 Javascript
使用基于Node.js的构建工具Grunt来发布ASP.NET MVC项目
2016/02/15 Javascript
js插件Jcrop自定义截取图片功能
2016/10/14 Javascript
纯js实现的积木(div层)拖动功能示例
2017/07/19 Javascript
Vue+Koa2+mongoose写一个像素绘板的实现方法
2019/09/10 Javascript
JQuery 实现文件下载的常用方法分析
2019/10/29 jQuery
Node.js API详解之 zlib模块用法分析
2020/05/19 Javascript
浅析Python中的多条件排序实现
2016/06/07 Python
Python实现二分查找与bisect模块详解
2017/01/13 Python
python selenium 对浏览器标签页进行关闭和切换的方法
2018/05/21 Python
在python中只选取列表中某一纵列的方法
2018/11/28 Python
Python实现简单查找最长子串功能示例
2019/02/26 Python
pyinstaller打包多个py文件和去除cmd黑框的方法
2019/06/21 Python
Django文件上传与下载(FileFlid)
2019/10/06 Python
Python算法中的时间复杂度问题
2019/11/19 Python
Python3 A*寻路算法实现方式
2019/12/24 Python
python3中布局背景颜色代码分析
2020/12/01 Python
美国环保婴儿用品公司:The Honest Company
2017/11/23 全球购物
环境建设实施方案
2014/03/14 职场文书
汽车广告策划方案
2014/05/31 职场文书
搞笑结婚保证书
2015/05/08 职场文书
幼儿园小班开学寄语
2015/05/27 职场文书
行政处罚听证告知书
2015/07/01 职场文书
2015暑期社会实践个人总结
2015/07/13 职场文书
企业安全生产规章制度
2015/08/06 职场文书
搞笑婚礼主持词开场白
2015/11/24 职场文书
Ajax实现三级联动效果
2021/10/05 Javascript
springmvc直接不经过controller访问WEB-INF中的页面问题
2022/02/24 Java/Android