4.mysql表约束 及 mysql库表设计范式

一:表的约束

1.1概念:

bash 复制代码
概念:约束是作用于表中字段上的规则,用于限制存储在表中的数据。
目的:保证数据库中数据的正确性、有效性、完整性和一致性。

注意:约束是作用于表中字段上的,可以在创建表/修改表时添加约束。
  • 分类
约束 描述
非空约束 限制该字段的数据不能为null
唯一约束 保证该字段所有数据唯一且不重复
主键约束 主键是一行数据的唯一标识,要求非空且唯一
默认约束 保存数据时未指定字段值,则采用默认值
检查约束 保证字段值满足某一个条件
外键约束 让两张表的数据之间建立联系,保证数据的一致性和完整性
  • 案例
bash 复制代码
1.查看未建表前的数据库
mysql> show tables;
+--------------------+
| Tables_in_it_heima |
+--------------------+
| employer           |
| score              |
+--------------------+

2.创建表(含约束)
mysql> create table user(
    -> id int auto_increment primary key comment"主键",
    -> name varchar(10) not null unique comment"姓名",
    -> age int check(age>0&&age<=120) comment"年龄",
    -> status char(1) default "1" comment"状态",
    -> gender char(1) comment"性别"
    -> );
Query OK, 0 rows affected, 1 warning (0.05 sec)

3.再次查看数据库,发现表已经创建成功
mysql> show tables;
+--------------------+
| Tables_in_it_heima |
+--------------------+
| employer           |
| score              |
| user               |
+--------------------+

1.2语法:

1.3非空约束:

1.4唯一约束:

1.5列描述---comment:

1.6主键约束---not null unique:

1.7主键自增:

1.8默认约束:

1.9外键约束:

  • 概念
bash 复制代码
外键用来让两张表的数据之间建立连接,从而保证数据的一致性和完整性
子表/从表:含有外键的表被称为子表;
父表/主表:外键关联的表被称为父表。
  • 语法
bash 复制代码
添加外键:
alter table 表名 add constraint 外键名称 foreign key(外键字段名) references 主表(主表列名); 

删除外键:
alter table 表名 drop foreign key 外键名称;

外键删除/更新行为:
行为 说明
no action/restrict 系统默认:父表有外键连接时,不允许删除/更新
cascade 有外键连接时,父表删除/更新,也删除/更新子表中的记录
set null 有外键连接时,父表删除/更新,设置子表外键值为null
  • 示例
bash 复制代码
要求如下:
1.创建部门表
2.创建员工表
3.将员工的部门id与部门表id外键连接
4.删除外键
5.重新建立外键约束,并指定删除/更新行为
bash 复制代码
1.创建部门表,并输入数据
create table dep(
    id int auto_increment comment 'ID' primary key,
    name varchar(50) not null comment '部门名称'
)comment '部门表';
  输入部门数据:
insert into dep (id, name) values (1, '研发部'), (2, '市场部'), (3, '财务部'), (4, '销售部'), (5, '总经办');

2.创建员工表,并输入数据
create table emp(
    id int auto_increment comment 'ID' primary key,
    name varchar(50) not null comment '姓名',
    age int comment '年龄',
    job varchar(20) comment '职位',
    salary int comment '薪资',
    entrydate date comment '入职时间',
    managerid int comment '直属领导ID',
    dep_id int comment '部门ID'
)comment '员工表';
  输入员工数据:
insert into emp (id, name, age, job, salary, entrydate, managerid, dep_id) values
(1, '金庸', 66, '总裁', 200000, '2000-01-01', null, 5),
(2, '张无忌', 20, '项目经理', 125000, '2005-12-05', 1, 1),
(3, '杨逍', 33, '开发', 84000, '2000-11-03', 2, 1),
(4, '韦一笑', 48, '开发', 110000, '2002-02-05', 2, 1),
(5, '常遇春', 43, '开发', 105000, '2004-09-07', 3, 1),
(6, '小昭', 19, '程序员鼓励师', 6600, '2004-10-12', 2, 1);

3.创建emp表dep_id与dep表id外键
alter table emp add constraint fk_emp_dep_id foreign key(dep_id) references dep(id);

4.删除外键
alter table emp drop foreign key fk_emp_dep_id;

5-1.重新建立外键,并指定删除/更新行为:cascade
alter table emp add constraint fk_emp_dep_id foreign key(dep_id) references dep(id) on update cascade on delete cascade;
5-2.重新建立外键,并指定删除/更新行为:set null
alter table emp add constraint fk_emp_dep_id foreign key(dep_id) references dep(id) on update set null on delete set null;

1.10检查约束:

1.11删除表的约束:

1.12存储引擎:

总结---完整的建表语句:

练习:

二:mysql库表设计---范式

2.1概念:

2.2第一范式(1NF):

2.3第二范式(2NF):

2.4第三范式(3NF):

相关推荐
看我干嘛!2 小时前
mysql主从配置一主一从
数据库·mysql
@insist1232 小时前
网络工程师-网络规划与设计(三):数据中心机房设计规范全解析
服务器·网络·数据库·网络工程师·软考·软件水平考试
2401_835956813 小时前
如何利用SQL子查询进行实时监控数据分析_性能优化
jvm·数据库·python
一只大袋鼠3 小时前
Java JDBC 封装:从原生写法到工具类封装 + 增删改查
java·开发语言·数据库·mysql
a9511416423 小时前
如何在Bootstrap中实现响应式的统计数据卡片
jvm·数据库·python
熬夜的咕噜猫3 小时前
Nosql Redis配置与优化
数据库·redis·nosql
椰猫子3 小时前
数据库(数据库相关概念、MySQL数据库、SQL(DDL、DML、DQL))
数据库·sql·mysql
Shorasul3 小时前
golang如何实现设备数据采集网关_golang设备数据采集网关实现要点
jvm·数据库·python
2301_764150563 小时前
如何用 some 检测数组中是否存在至少一个满足条件的项
jvm·数据库·python
j_xxx404_3 小时前
数据库基础夯实:从零手写DDL与DML,MySQL核心语法实战解析
数据库·mysql