详解sql中的参照完整性(一对一,一对多,多对多)
16lz
2021-12-23
一、参照完整性
参照完整性指的就是多表之间的设计,主要使用外键约束。
多表设计: 一对多、多对多、一对一设计
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);
更多相关文章
- MySQL系列多表连接查询92及99语法示例详解教程
- Android(安卓)- Manifest 文件 详解
- Android的Handler机制详解3_Looper.looper()不会卡死主线程
- Selector、shape详解(一)
- android2.2资源文件详解4--menu文件夹下的菜单定义
- Android发送短信方法实例详解
- Android(安卓)读取资源文件实例详解
- 详解Android中的屏幕方向
- Android学习笔记(10)————Android的Listview详解1(ArrayAdapte