一、参照完整性

参照完整性指的就是多表之间的设计,主要使用外键约束。
多表设计: 一对多、多对多、一对一设计

1.一对多

关联主要语句:
constraint cus_ord_fk foreign key (customer_id) REFERENCES customer(id)
创建客户表——订单表
一个客户可以订多份订单,每份订单只能有一个客户。

-- 关联(1对N)create table customer(id int PRIMARY KEY auto_increment,name varchar (20) not null,adress varchar (20) not null);create table orders(order_num varchar(20) PRIMARY KEY,price FLOAT not NULL,customer_id int, -- 进行和customer 关联的字段 外键constraint cus_ord_fk foreign key (customer_id) REFERENCES customer(id));insert into customer(name,adress) values("zs","北京");insert into customer(name,adress) values("ls","上海");SELECT * from customer;INSERT INTO orders values("010",30.5,1);INSERT INTO orders values("011",60.5,2);INSERT INTO orders values("012",120.5,1);SELECT * from orders;

创建学生——老师关系表格
其中一个学生可以有多个老师,一位老师也可以有多个学生

-- 多对多关系-- 创建teacher表格CREATE TABLE teacher (id INT,NAME VARCHAR (20) NOT NULL,gender CHAR (2) NOT NULL,PRIMARY KEY (id));-- 创建学生表格CREATE TABLE student (id INT,NAME VARCHAR (20) NOT NULL,age INT NOT NULL);ALTER TABLE student ADD PRIMARY KEY (id);-- 第三张关系表CREATE TABLE tch_std (teacher_id INT,student_id INT,CONSTRAINT fk_teacher FOREIGN KEY (teacher_id) REFERENCES teacher (id),CONSTRAINT fk_student FOREIGN KEY (student_id) REFERENCES teacher (id));DELETEFROMteacherWHEREid = 3;SELECT*FROMteacher;SELECT DISTINCT*FROMtch_std;

3. 一对一

两种形式:

1)按照外键关联
在IdCard表中的外键添加唯一约束
2)按照主键关联
对主键添加外键约束

-- 一对一-- 创建users表格CREATE TABLE users (id INT,NAME VARCHAR (20) NOT NULL,gender CHAR (2) NOT NULL,PRIMARY KEY (id));-- 创建card 表格CREATE TABLE card (id INT,adress VARCHAR (100) NOT NULL,user_id INT UNIQUE,constraint users_id_fk foreign key(user_id) references users(id));ALTER TABLE card ADD PRIMARY KEY (id);

更多相关文章

  1. MySQL系列多表连接查询92及99语法示例详解教程
  2. Android(安卓)- Manifest 文件 详解
  3. Android的Handler机制详解3_Looper.looper()不会卡死主线程
  4. Selector、shape详解(一)
  5. android2.2资源文件详解4--menu文件夹下的菜单定义
  6. Android发送短信方法实例详解
  7. Android(安卓)读取资源文件实例详解
  8. 详解Android中的屏幕方向
  9. Android学习笔记(10)————Android的Listview详解1(ArrayAdapte

随机推荐

  1. IDEA最新激活码2021(IDEA2020.3永久激活方
  2. 一文读懂 SuperEdge 边缘容器架构与原理
  3. CCNP(ISCW)实验:使用SDM配置路由器
  4. 循环链表(单双链表)
  5. Android的View组件的几大子类
  6. 一篇文章教会你搭建自己的linux虚拟机
  7. Zabbix5.0服务端和客户端安装
  8. MySQL 百万级数据分页查询及优化
  9. 【开发者必看】2020年移动应用趋势洞察白
  10. Redis系列5-实现简单消息队列