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 相关文章推荐
数据库的高级查询六:表连接查询:外连接(左外连接,右外连接,UNION关键字,连接中ON与WHERE的不同)
Apr 05 MySQL
linux下导入、导出mysql数据库命令的实现方法
May 26 MySQL
MySQL系列之八 MySQL服务器变量
Jul 02 MySQL
解决mysql的int型主键自增问题
Jul 15 MySQL
为什么MySQL选择Repeatable Read作为默认隔离级别
Jul 26 MySQL
VS2019连接MySQL数据库的过程及常见问题总结
Nov 27 MySQL
教你如何让spark sql写mysql的时候支持update操作
Feb 15 MySQL
MySQL优化常用的19种有效方法(推荐!)
Mar 17 MySQL
Mysql 8.x 创建用户以及授予权限的操作记录
Apr 18 MySQL
mysql5.5中文乱码问题解决的有用方法
May 30 MySQL
SQL语句中EXISTS的详细用法大全
Jun 25 MySQL
SQLServer常见数学函数梳理总结
Aug 05 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
融入意大利的咖啡文化
2021/03/03 咖啡文化
phpMyadmin 用户权限中英对照
2010/04/02 PHP
使用JSON实现数据的跨域传输的php代码
2011/12/20 PHP
php根据分类合并数组的方法实例详解
2013/11/06 PHP
浅析PHP编程中10个最常见的错误
2014/08/08 PHP
mac环境中使用brew安装php5.5.15
2014/08/18 PHP
php字符串函数学习之substr()
2015/03/27 PHP
PHP中使用foreach()遍历二维数组的简单实例
2016/06/13 PHP
php+lottery.js实现九宫格抽奖功能
2019/07/21 PHP
PHP与Web页面的交互示例详解一
2020/08/04 PHP
一些主流JS框架中DOMReady事件的实现小结
2011/02/12 Javascript
js 字符串转化成数字的代码
2011/06/29 Javascript
基于jQuery判断两个元素是否有重叠部分的代码
2012/07/25 Javascript
利用Jquery实现可多选的下拉框
2014/02/21 Javascript
深入理解Javascript里的依赖注入
2014/03/19 Javascript
js常用数组操作方法简明总结
2014/06/20 Javascript
javascript解析xml实现省市县三级联动的方法
2015/07/25 Javascript
jQuery手动点击实现图片轮播特效
2020/04/20 Javascript
bootstrap datetimepicker2.3.11时间插件使用
2016/11/19 Javascript
微信小程序实现简易table表格
2020/06/19 Javascript
Vue页面切换和a链接的本质区别详解
2019/11/12 Javascript
Python with的用法
2014/08/22 Python
python导入时小括号大作用
2017/01/10 Python
scrapy spider的几种爬取方式实例代码
2018/01/25 Python
Python数据结构之图的应用示例
2018/05/11 Python
python读取和保存图片5种方法对比
2018/09/12 Python
python打开windows应用程序的实例
2019/06/28 Python
python 利用turtle模块画出没有角的方格
2019/11/23 Python
Pytorch提取模型特征向量保存至csv的例子
2020/01/03 Python
如何通过python计算圆周率PI
2020/11/11 Python
selenium3.0+python之环境搭建的方法步骤
2021/02/01 Python
犹他州最古老的体育用品公司:Al’s
2020/12/18 全球购物
软弱涣散基层党组织整改方案
2014/10/25 职场文书
大卫科波菲尔读书笔记
2015/06/30 职场文书
Python 中的单分派泛函数你真的了解吗
2021/06/22 Python
使用opencv-python如何打开USB或者笔记本前置摄像头
2022/06/21 Python