我的编程空间,编程开发者的网络收藏夹
学习永远不晚

MySQL数据库的多表操作

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

MySQL数据库的多表操作

一、 数据库的多表操作

数据库的多表关系:

  • 一对一
  • 一对多
  • 多对一
  • 多对多

二,操作

一对一

建立数据表personcard,设置person数据表id为主键且自增,设置cardid为外键

// 创建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 (
	id 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表操作内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

MySQL数据库的多表操作

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

MySQL数据库的多表操作

这篇文章主要介绍了MySQL数据库的多表操作,文章围绕主题展开详细的内容介绍,具有一定的参考价值,感兴趣的小伙伴可以参考一下,希望对你的学习有所帮助
2022-11-13

MySQL 操作数据库、数据表

通过mysql-client连接到mysql-server,sql语句要以分号结尾,这样按Enter才会执行sql语句。mysql关键字不区分大小写字符串、时间日期类型的值要引起来  数据库操作show databases; #显示已有的数据库create
MySQL  操作数据库、数据表
2016-11-30

【MySQL】数据库和表的操作

数据库和表的操作 一、数据库的操作1. 创建数据库2. 字符集和校验规则(1)查看系统默认字符集以及校验规则(2)查看数据库支持的字符集(3)查看数据库支持的字符集校验规则(4)校验规则对数据库的影响 3. 操纵数据库(1)查
【MySQL】数据库和表的操作
2023-12-22

【数据库_03】MySQL-多表操作与事务

二、子查询 1. 子查询的位置 ① 什么是子查询 * select 嵌套查询 * 示例 select ename,(select ename from emp m where t.mgr = m.id)
【数据库_03】MySQL-多表操作与事务
2018-04-16

MySQL数据库(四)数据库和表操作

4.1 连接在最初安装MySQL,可能会要求你输入一个管理登录(通常为root)和一个口令(密码)。连接MySQL需要以下信息:主机名(计算机名)——如果连接到本地MySQL服务器,为localhost;端口(如果使用默认端口3306之外的端口);一个合法的用
MySQL数据库(四)数据库和表操作
2018-05-11

MySQL数据库中表的操作详解

目录1.mysql中的数据类型2.创建数据表3.删除表4.插入数据5.更新数据6.删除数据7.快速复制表8.快速删除表数据1.Mysql中的数据类型varchar 动态字符串类型(最长255位),可以根据实际长度来动态分配空间,例如:va
2022-08-18

mysql-数据库的操作

系统数据库执行如下命令,查看系统所有的数据库mysql> show databases;+--------------------+| Database |+--------------------+| information_s
2023-01-30

MYSQL对数据库和表的基本操作

CREATE DATABASE testdb CHARSET=UTF8创建一个数据库 名字叫做testdbUSE testdb;选择数据库 CREATE TABLE testTable1( -> id int(11) not null primary k
MYSQL对数据库和表的基本操作
2020-05-25

编程热搜

目录