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):

相关推荐
倔强的石头_7 小时前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
云技纵横7 小时前
唯一索引 INSERT 死锁实战:5 秒复现交叉插入的 S 锁循环等待
sql·mysql
沉默王二7 小时前
面试官:RAG 不用向量数据库,用 MySQL 硬扛?我:100 万向量不是很轻松?
mysql·面试·ai编程
冬奇Lab20 小时前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
小猿姐1 天前
MySQL Top 10 热点问题 AI 运维实战:从内核诊断到云原生运维
mysql·云原生·aiops
ClouGence1 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle
云技纵横1 天前
Gap Lock 死锁实战:5 秒在本地复现 MySQL 间隙锁死锁
后端·mysql
无响应de神1 天前
三、用户与权限管理
数据库·mysql
摇滚侠2 天前
Linux CentOS7 rpm 安装 MySQL 5.7
linux·运维·mysql