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 05 MySQL
MySQL获取所有分类的前N条记录
May 07 MySQL
MySQL为id选择合适的数据类型
Jun 07 MySQL
MySQL开启事务的方式
Jun 26 MySQL
MySQL系列之二 多实例配置
Jul 02 MySQL
详解Mysql数据库平滑扩容解决高并发和大数据量问题
May 25 MySQL
MySQL 语句执行顺序举例解析
Jun 05 MySQL
MySQL中JOIN连接的基本用法实例
Jun 05 MySQL
MySQL数据库实验之 触发器和存储过程
Jun 21 MySQL
mysql sock 文件解析及作用讲解
Jul 15 MySQL
MySQL 原理与优化之原数据锁的应用
Aug 14 MySQL
MySQL 原理与优化之Limit 查询优化
Aug 14 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)
2010/09/04 PHP
PHP 字符串长度判断效率更高的方法
2014/03/02 PHP
Yii2.0多文件上传实例说明
2017/07/24 PHP
js中cookie的使用详细分析
2008/05/28 Javascript
JavaScript 对象链式操作测试代码
2010/04/25 Javascript
JavaScript 原型与继承说明
2010/06/09 Javascript
javascript:window.open弹出窗口的位置问题
2014/03/18 Javascript
javascript原型链继承用法实例分析
2015/01/28 Javascript
ECMAScript 5严格模式(Strict Mode)介绍
2015/03/02 Javascript
原生js实现移动开发轮播图、相册滑动特效
2015/04/17 Javascript
jquery 重写 ajax提交并判断权限后 使用load方法报错解决方法
2016/01/19 Javascript
Bootstrap入门书籍之(零)Bootstrap简介
2016/02/17 Javascript
Javascript的表单验证-初识正则表达式
2016/03/18 Javascript
ES6中参数的默认值语法介绍
2017/05/03 Javascript
详解微信小程序中的页面代码中的模板的封装
2017/10/12 Javascript
微信小程序中使用ECharts 异步加载数据的方法
2018/06/27 Javascript
详解mpvue中使用vant时需要注意的onChange事件的坑
2019/05/16 Javascript
微信小程序实现写入读取缓存详解
2019/08/30 Javascript
vue 使用插槽分发内容操作示例【单个插槽、具名插槽、作用域插槽】
2020/03/06 Javascript
js实现拖拽与碰撞检测
2020/09/18 Javascript
利用PHP实现递归删除链表元素的方法示例
2020/10/23 Javascript
python实现定时发送qq消息
2019/01/18 Python
网易有道2017内推编程题 洗牌(python)
2019/06/19 Python
python正则表达式匹配不包含某几个字符的字符串方法
2019/07/23 Python
Python模拟伯努利试验和二项分布代码实例
2020/05/27 Python
会议开场欢迎词
2014/01/15 职场文书
留学推荐信中文范文三篇
2014/01/25 职场文书
给老婆大人的检讨书
2014/02/24 职场文书
生物工程专业求职信
2014/09/03 职场文书
小学趣味运动会加油稿
2014/09/25 职场文书
2014年部门工作总结
2014/11/12 职场文书
2015年试用期自我评价范文
2015/03/10 职场文书
清明祭英烈活动总结
2015/05/11 职场文书
学历证明范文
2015/06/16 职场文书
关于感恩的素材句子(38句)
2019/11/11 职场文书
Java使用HttpClient实现文件下载
2022/08/14 Java/Android