多表关系
一对一关系
-
用户和用户详情
-
关系:一对一的关系
-
用途:用于单表拆分,将一张表的基础字段放在一张表中,其它字段放在另一张表中,可以提升查询效率
-
实现:在任意一张表里面添加外键,关联另一张表的主键
CREATE TABLE `user_detail` ( `id` int NOT NULL AUTO_INCREMENT, `university` varchar(255) DEFAULT NULL, `car` varchar(255) DEFAULT NULL, `hourse` varchar(255) DEFAULT NULL, `user_id` int NOT NULL UNIQUE, PRIMARY KEY (`id`) USING BTREE, KEY `u_id` (`user_id`), CONSTRAINT `u_id` FOREIGN KEY (`user_id`) REFERENCES `user` (`id`) ON DELETE CASCADE ON UPDATE CASCADE ) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci;
一对多关系
-
案例:部门和员工关系
-
关系:一个部门对应多个员工,一个员工对应一个部门
-
实现:在多的一方建立外键,指向一的一方的主键
多对多的关系
-
案例:角色和菜单的关系,学生和老师
-
关系:一个学生可以有多个老师,一个老师可以有多个学生
-
实现:建立三方表,中间表来包含两个表的主键