MySQL示例讲解数据库约束以及表的设计


Posted in MySQL onJune 16, 2022

数据库约束

not null

指定某列的存储不能为null值

create table student (id int not null,name varchar(20));
Query OK, 0 rows affected (0.01 sec)
mysql> desc student;
+-------+-------------+------+-----+---------+-------+
| Field | Type        | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| id    | int(11)     | NO   |     | NULL    |       |
| name  | varchar(20) | YES  |     | NULL    |       |
+-------+-------------+------+-----+---------+-------+
2 rows in set (0.00 sec)

unique

保证某列必须有唯一的值,插入重复的值就会报错

default

规定给列赋值时的默认值

create table student(id int,name varchar(20) default '匿名');

primary key 主键

主键约束,是not null 与unique的结合,确保某列的赋值不能为null,并且是唯一的

auto_increment 自增特点:

1.如果表中没有记录,自增从1开始

2.如果有数据,从上一条记录往下自增

3.插入再删掉数据,自增的值不会重复利用,会按删掉的那条开始自增

create table student (id int primary key auto_increment,name varchar(20));
Query OK, 0 rows affected (0.01 sec)
mysql> desc student;
+-------+-------------+------+-----+---------+----------------+
| Field | Type        | Null | Key | Default | Extra          |
+-------+-------------+------+-----+---------+----------------+
| id    | int(11)     | NO   | PRI | NULL    | auto_increment |
| name  | varchar(20) | YES  |     | NULL    |                |
+-------+-------------+------+-----+---------+----------------+
2 rows in set (0.00 sec)
mysql> insert into student values(null,'张三');
Query OK, 1 row affected (0.00 sec)
mysql> select * from student;
+----+--------+
| id | name   |
+----+--------+
|  1 | 张三   |
+----+--------+
1 row in set (0.00 sec)

foreign key 外键

外键约束,在表一中的数据必须在表二中存在,要参照完整性准则

外键约束描述的是两张表的两个列之间的“依赖关系”

外键约束会影响表的删除,例如下面的实例的class表被关联,所以它不能被轻易删除

mysql> create table class (
    -> id int primary key,
    -> name varchar(20) not null
    -> );
Query OK, 0 rows affected (0.04 sec)
mysql> create table student (
    -> id int primary key,
    -> name varchar(20) not null,
    -> email varchar(20) default 'unknow',
    -> QQ varchar(20) unique,
    -> classId int , foreign key (classId) references class(id)
    -> );
Query OK, 0 rows affected (0.03 sec)
mysql> desc class;
+-------+-------------+------+-----+---------+-------+
| Field | Type        | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| id    | int(11)     | NO   | PRI | NULL    |       |
| name  | varchar(20) | NO   |     | NULL    |       |
+-------+-------------+------+-----+---------+-------+
2 rows in set (0.02 sec)

mysql> desc student;
+---------+-------------+------+-----+---------+-------+
| Field   | Type        | Null | Key | Default | Extra |
+---------+-------------+------+-----+---------+-------+
| id      | int(11)     | NO   | PRI | NULL    |       |
| name    | varchar(20) | NO   |     | NULL    |       |
| email   | varchar(20) | YES  |     | unknow  |       |
| QQ      | varchar(20) | YES  | UNI | NULL    |       |
| classId | int(11)     | YES  | MUL | NULL    |       |
+---------+-------------+------+-----+---------+-------+
5 rows in set (0.00 sec)

check

指定一个条件,通过条件来对值进行判定

但是mysql并不支持

create table test_user (
   id int,
   name varchar(20),
   sex varchar(1),
   check (sex ='男' or sex='女')
);

表的设计

一对一

一对一设计表就比如学生表和账户表,一个账户对应到一个学生,一个学生也只有一个账户

表示方法

1.可以把这两个实体用一张表来表示

2.可以用两张表来表示,其中一张表包含了另一个表的id

一对多

一个学生应该处于一个班级中,一个班级可以包含多个学生

表示方法:

1.在班级表中,新增一列,表示这个班级里的学生id都有啥(mysql没有数组类型,redis可以)

2.班级表不变,学生表中,新增一列classId

多对多

多对多设计表就好比学生表和课程表,一个学生可以选多个课程,一个课程也可以被多个学生选择

表示方法 :

使用一个关联表,来表示两个实体之间的关系

多对多建表实例

-- 学生表
mysql> create table test_student (
    -> id int primary key,
    -> name varchar(10) default 'unknow'
    -> );
Query OK, 0 rows affected (0.03 sec)
-- 选课表
mysql> create table test_course (
    -> id int primary key,
    -> name varchar(20) default 'unknow'
    -> );
Query OK, 0 rows affected (0.02 sec)
-- 成绩表
mysql> create table test_score (
    -> studentId int,
    -> courseId int,
    -> score int,
    -> foreign key (studentId) references test_student(id),
    -> foreign key (courseId) references test_course(id)
    -> );
Query OK, 0 rows affected (0.02 sec)

mysql> desc test_student;
+-------+-------------+------+-----+---------+-------+
| Field | Type        | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| id    | int(11)     | NO   | PRI | NULL    |       |
| name  | varchar(10) | YES  |     | unknow  |       |
+-------+-------------+------+-----+---------+-------+
2 rows in set (0.00 sec)

mysql> desc test_coures;
ERROR 1146 (42S02): Table 'java_5_27.test_coures' doesn't exist
mysql> desc test_course;
+-------+-------------+------+-----+---------+-------+
| Field | Type        | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| id    | int(11)     | NO   | PRI | NULL    |       |
| name  | varchar(20) | YES  |     | unknow  |       |
+-------+-------------+------+-----+---------+-------+
2 rows in set (0.00 sec)

mysql> desc test_score;
+-----------+---------+------+-----+---------+-------+
| Field     | Type    | Null | Key | Default | Extra |
+-----------+---------+------+-----+---------+-------+
| studentId | int(11) | YES  | MUL | NULL    |       |
| courseId  | int(11) | YES  | MUL | NULL    |       |
| score     | int(11) | YES  |     | NULL    |       |
+-----------+---------+------+-----+---------+-------+
3 rows in set (0.00 sec)

插入数据到实例实现多对多

mysql> insert into test_student values (1, 'listen');
Query OK, 1 row affected (0.01 sec)

mysql> insert into test_course values (1, '数学');
Query OK, 1 row affected (0.00 sec)

mysql> insert into test_student values (2, 'Faker');
Query OK, 1 row affected (0.00 sec)

mysql> insert into test_course values (2, '数学');
Query OK, 1 row affected (0.00 sec)

mysql> insert into test_score values(1, 1, 90);
Query OK, 1 row affected (0.00 sec)

mysql> insert into test_score values (1, 2, 99);
Query OK, 1 row affected (0.00 sec)

mysql> insert into test_score values (2, 1, 50);
Query OK, 1 row affected (0.00 sec)

mysql> insert into test_score values (2, 2, 60);
Query OK, 1 row affected (0.00 sec)

mysql> select * from test_student;
+----+--------+
| id | name   |
+----+--------+
|  1 | listen |
|  2 | Faker  |
+----+--------+
2 rows in set (0.00 sec)

mysql> select * from test_course;
+----+--------+
| id | name   |
+----+--------+
|  1 | 数学   |
|  2 | 语文   |
+----+--------+
2 rows in set (0.00 sec)

mysql> select * from test_score;
+-----------+----------+-------+
| studentId | courseId | score |
+-----------+----------+-------+
|         1 |        1 |    90 |
|         1 |        2 |    99 |
|         2 |        1 |    50 |
|         2 |        2 |    60 |
+-----------+----------+-------+
4 rows in set (0.00 sec)

到此这篇关于MySQL示例讲解数据库约束以及表的设计的文章就介绍到这了,更多相关MySQL数据库约束内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

MySQL 相关文章推荐
MySQL主从复制断开的常用修复方法
Apr 07 MySQL
MySQL创建索引需要了解的
Apr 08 MySQL
MySQL 慢查询日志深入理解
Apr 22 MySQL
MySQL索引知识的一些小妙招总结
May 10 MySQL
浅谈MySQL 亿级数据分页的优化
Jun 15 MySQL
详解MySQL多版本并发控制机制(MVCC)源码
Jun 23 MySQL
MYSQL 运算符总结
Nov 11 MySQL
MySQL图形化管理工具Navicat安装步骤
Dec 04 MySQL
详解MySQL中timestamp和datetime时区问题导致做DTS遇到的坑
Dec 06 MySQL
mysql 索引的数据结构为什么要采用B+树
Apr 26 MySQL
mysql序号rownum行号实现方式
Dec 24 MySQL
mysql幻读详解实例以及解决办法
Jun 16 #MySQL
mysql数据库隔离级别详解
Jun 16 #MySQL
MySQL解决Navicat设置默认字符串时的报错问题
Jun 16 #MySQL
MySQL数据库之内置函数和自定义函数 function
Jun 16 #MySQL
MySQL数据库之存储过程 procedure
Jun 16 #MySQL
MySQL8.0 Undo Tablespace管理详解
Jun 16 #MySQL
MySQL串行化隔离级别(间隙锁实现)
Jun 16 #MySQL
You might like
PHP使用JSON和将json还原成数组
2015/02/12 PHP
PHP调用.NET的WebService 简单实例
2015/03/27 PHP
PHP数组生成XML格式数据的封装类实例
2016/11/10 PHP
js电信网通双线自动选择技巧
2008/11/18 Javascript
javascript 异常处理使用总结
2009/06/21 Javascript
jquery ajax 登录验证实现代码
2009/09/23 Javascript
深入理解JavaScript系列(3) 全面解析Module模式
2012/01/15 Javascript
cookie 最近浏览记录(中文escape转码)具体实现
2013/06/08 Javascript
javascript中RegExp保留小数点后几位数的方法分享
2013/08/13 Javascript
快速解决jQuery与其他库冲突的方法介绍
2014/01/02 Javascript
jQuery内部原理和实现方式浅析
2015/02/03 Javascript
angularjs学习笔记之简单介绍
2015/09/26 Javascript
Bootstrap进度条组件知识详解
2016/05/01 Javascript
angularjs $http实现form表单提交示例
2017/06/09 Javascript
NodeJS 实现手机短信验证模块阿里大于功能
2017/06/19 NodeJs
详解通过源码解析Node.js中cluster模块的主要功能实现
2018/05/16 Javascript
mpvue+vuex搭建小程序详细教程(完整步骤)
2018/09/30 Javascript
关于React动态加载路由处理的相关问题
2019/01/07 Javascript
使用Vue实现一个树组件的示例
2020/11/06 Javascript
举例讲解Python中的算数运算符的用法
2015/05/13 Python
使用Python来开发Markdown脚本扩展的实例分享
2016/03/04 Python
Python简单连接MongoDB数据库的方法
2016/03/15 Python
python爬取NUS-WIDE数据库图片
2016/10/05 Python
Python获取本机所有网卡ip,掩码和广播地址实例代码
2018/01/22 Python
Python socket实现的简单通信功能示例
2018/08/21 Python
python使用beautifulsoup4爬取酷狗音乐代码实例
2019/12/04 Python
基于Keras的格式化输出Loss实现方式
2020/06/17 Python
Python三维绘图之Matplotlib库的使用方法
2020/09/20 Python
python实现录音功能(可随时停止录音)
2020/10/26 Python
多重CSS背景动画实现方法示例
2014/04/04 HTML / CSS
俄罗斯皮肤健康中心:Pharmacosmetica.ru
2020/02/22 全球购物
幼儿园小班教师寄语
2014/04/03 职场文书
大连导游词
2015/02/12 职场文书
jupyter notebook保存文件默认路径更改方法汇总(亲测可以)
2021/06/09 Python
Mysql binlog日志文件过大的解决
2021/10/05 MySQL
Android中的Launch Mode详情
2022/06/05 Java/Android