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批量新增和存储的方法实例
Apr 07 MySQL
Idea连接MySQL数据库出现中文乱码的问题
Apr 14 MySQL
MySQL EXPLAIN输出列的详细解释
May 12 MySQL
MySQL系列之开篇 MySQL关系型数据库基础概念
Jul 02 MySQL
浅谈MySQL函数
Oct 05 MySQL
MySQL限制查询和数据排序介绍
Mar 25 MySQL
MySQL数据库优化之通过索引解决SQL性能问题
Apr 10 MySQL
MySQL分区以及建索引的方法总结
Apr 13 MySQL
详解Mysql数据库平滑扩容解决高并发和大数据量问题
May 25 MySQL
MySQL数据库简介与基本操作
May 30 MySQL
MySQL数据库安装方法与图形化管理工具介绍
May 30 MySQL
关于mysql中string和number的转换问题
Jun 14 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
ubuntu12.04使用c编写php扩展模块教程分享
2013/12/25 PHP
PHP操作Redis常用命令的实例详解
2020/12/23 PHP
javascript事件模型代码
2007/07/01 Javascript
JS实现在Repeater控件中创建可隐藏区域的代码
2010/09/16 Javascript
javascript学习笔记(三)显示当时时间的代码
2011/04/08 Javascript
html+javascript实现可拖动可提交的弹出层对话框效果
2013/08/05 Javascript
常用jQuery代码分享
2015/07/14 Javascript
angularJS与bootstrap结合实现动态加载弹出提示内容
2015/10/16 Javascript
Bootstrap实现默认导航栏效果
2020/09/21 Javascript
Javascript实现鼠标框选操作  不是点击选取
2016/04/14 Javascript
JavaScript与java语言有什么不同
2016/09/22 Javascript
Linux使用Node.js建立访问静态网页的服务实例详解
2017/03/21 Javascript
Angular 4.x 动态创建表单实例
2017/04/25 Javascript
基于Vue-cli快速搭建项目的完整步骤
2018/11/03 Javascript
vue+element+Java实现批量删除功能
2019/04/08 Javascript
微信公众平台 发送模板消息(Java接口开发)
2019/04/17 Javascript
使用JS监听键盘按下事件(keydown event)
2019/11/07 Javascript
JavaScript JSON使用原理及注意事项
2020/07/30 Javascript
[03:49]显微镜下的DOTA2第十五期—VG登基之路完美团
2014/06/24 DOTA
[02:03]风行者至宝清风环佩外观展示
2020/09/05 DOTA
Python在线运行代码助手
2016/07/15 Python
PythonWeb项目Django部署在Ubuntu18.04腾讯云主机上
2019/04/01 Python
python3中pip3安装出错,找不到SSL的解决方式
2019/12/12 Python
matplotlib 画动态图以及plt.ion()和plt.ioff()的使用详解
2021/01/05 Python
CSS3 真的会替代 SCSS 吗
2021/03/09 HTML / CSS
做一个能自适应高度的textarea的示例代码
2019/09/06 HTML / CSS
创业计划书中要认真思考的问题
2013/12/28 职场文书
机关财务管理制度
2014/01/17 职场文书
餐厅考勤管理制度
2014/01/28 职场文书
自荐信如何制作?
2014/02/21 职场文书
农村改厕实施方案
2014/03/22 职场文书
竞选学委演讲稿
2014/09/13 职场文书
公司离职证明范本
2014/10/17 职场文书
详解Python中下划线的5种含义
2021/07/15 Python
动画电影《龙珠超 超级英雄》延期上映
2022/03/20 日漫
浅谈Vue的computed计算属性
2022/03/21 Vue.js