目录一、数据库的多表操作二,操作一对一一对多一、数据库的多表操作数据库的多表关系:一对一一对多多对一多对多二,操作一对一建立数据表person和card,设置person数据表id为主键且自增,设...
一、 数据库的多表操作
- 一对一
- 一对多
- 多对一
- 多对多
二,操作
一对一
建立数据表person
和card
,设置person
数据表id
为主键且自增,设置card
的id
为外键
// 创建person表
CREATE TABLE person (
id INT PRIMARY KEY AUTO_INCREMENT, // 主键 自增
NAME VARCHAR(20)
);
// 创建card表
CREATE TABLE card (
id INT PRIMARY KEY AUTO_INCREMENT, // 主键 自增
number VARCHAR(20) UNIQUE NOT NULL,// 不能为null
pid INT UNIQUE,// pid唯一
CONSTRAINT cp_fk1 FOREIGN KEY (pid) REFERENCES person(id) // 外键列
);
一对多
创建user数据表和orderlist数据表,这里不再设置uid为唯一值,因此是一对多的关系
// 创建user表
CREATE TABLE USER(
id INT PRIMARY KEY AUTO_INCREMENT, // 主键 自增
NAME VARCHAR(20)
);
// 添加数据
INSERT INTO USER VALUES (NULL, '张三'),(NULL, '李四');
// 创建orderlist表
CREATE TABLE orderlist(
id INT PRIMARY KEY AUTO_INCREMENT,
number VARCHAR(20),
uid INT, // 这里没有再设置唯一值
CONSTRAINT out_fk1 FOREIGN KEY (uid) REFERENCES USER(id) // 外键列
);
-- 添加数据
INSERT INTO orderlist VALUES (NULL, 'hm001', 1), (NULL, 'hm002', 1),(NULL, 'hm003', 2),(NULL, 'hm004', 2);
- 多对多 创建student数据表,设置主键,再创建course数据表,创建中间表将两者关联起来
// 创建student表
CREATE TABLE student(
id INT PRIMARY KEY AUTO_INCREMENT,
NAME VARCHAR(20)
);
// 创建course表
CREATE TABLE course (
idandroid INT PRIMARY KEY AUTO_INCREMENT,
NAME VARCHAR(10)
);
// 创建中间表
CREATE TABLE stu_course(
id INT PRIMARY KEY AUTO_INCREMENT,
sid INT,
cid INT,
CONSTRAINT sc_fk1 FOREIGN KEY (sid) REFERENCES student(id),// 设置外键
CONSTRAINT sc_fk2 FOREIGN KEY (cid) REFERENCES course(id)// 设置外键
);
通过规定语法,进行内链查询
// 标准语法: SELECT 列名 FROM 表名1 [INNER] JOIN 表名2 ON 关联条件;
-- 查询用户信息和对应的订单信息
SELECT * FROM USER INNER JOIN orderlist ON orderlist.uid = user.id;
// 设置别名进行查询
SELECT u.name, u.age, o.number FROM USER u INNER JOIN orderlist o ON o.uid = u.id;
// 标准语法: SELECT 列名 FROM 表名1,表名2 WHERE 关联条件;
// 查询用户姓名,年龄。和订单编号
SELECT u.name, u.age, o.number FROM USER u, orderlist o WHERE o.uid = uid;
标准语法: SELECT 列名 FROM 表名1 LEFT [OUTER] JOIN 表名2 ON 条件;
// 查询所有用户信息,以及用户对应的订单信息
SELECT u.* o.number FROM USER u LEFT OUTER JOIN orderlist o ON o.uid = u.id;
标准语法: SELECT 列名 FROM 表名1 RIGHT [OUTER] JOIN 表名2 ON 条件;
// 查询所有订单信息,以及订单所属的用户信息
SELECT o.*, u.name FROM USER u RIGHT OUTER JOIN orderlist o ON o.uid = u.id;
// 结果是单行单列的
// 标准语法: SELECT 列名 FROM 表名 WHERE 列名=(SELECT 列名 FROM 表名 [WHERE 条件]);
// 查询年龄最高的用户姓名
SELECT NAME,age FROM USER WHERE age=(SELECT MAX(age) FROM USER);
// 结果是多行单列的
// 标准语法:SELECT 列名 FROM 表名 WHERE 列名 [NOT] IN (SELECT 列名 FROM 表名 [WHERE 条件]);
// 查询张三和李四的订单信息
SELECT * FROM orderlist WHERE uid IN (SELECT id FROM USER WHERE NAME IN ('张三','李四'));
// 结果是多行多列的
// 标准语法: SELECT 列名 FROM 表名 [别名],(SELECT 列名 FROM 表名 [WHERE 条件]) [别名] [WHERE 条件];
// 查询订单表中id大于4的订单信息和所属用户信息
SELECT u.name, o.number FROM USER u, (SELECT * FROM orderlist WHERE id > 4) o WHERE o.uid=u.id;
到此这篇关于mysql数据库的多表操作的文章就介绍到这了,更多相关MySQL表操作内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!
沃梦达教程
本文标题为:MySQL数据库的多表操作
猜你喜欢
- 基于Python制作一个简单的文章搜索工具 2023-07-28
- Mongodb启动报错完美解决方案:about to fork child process,waiting until server is ready for connections. 2023-07-16
- SQL Server 2022 AlwaysOn新特性之包含可用性组详解 2023-07-29
- redis清除数据 2023-09-13
- Numpy中如何创建矩阵并等间隔抽取数据 2023-07-28
- MySQL8.0.28安装教程详细图解(windows 64位) 2023-07-26
- 搭建单机Redis缓存服务的实现 2023-07-13
- Oracle 删除大量表记录操作分析总结 2023-07-23
- 在阿里云CentOS 6.8上安装Redis 2023-09-12
- SQLSERVER调用C#的代码实现 2023-07-29