首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

⑧【MySQL数据库查询:内连接、外连接、自连接、子查询、多表查询

、子查询、多表查询 ⑧MySQL数据库查询 1....多表关系 多表关系: 一对一 :在任意一方加入外键,关联另一方的主键,并设置外键为唯一(UNIQUE)。 一对多(多对一) :在多的一方建立外键,指向一的一方的主键。...多表查询 多表查询: 在多张表查询数据。 笛卡尔积:两个集合,集合A 与 集合B中元素的所有组合情况,在多表查询时需要使用WHERE关键字或 JOIN ON关键字消除笛卡尔积。...内连接 —— INNER JOIN 连接查询 —— 内连接: 内连接: ①隐式内连接 SELECT 字段列表 FROM 表1,表2 WHERE 连接条件...; ②显示内连接 SELECT 字段列表 FROM...`id`; 自连接 —— JOIN 连接查询 —— 自连接: 自连接: ①自连接查询,可以是内连接查询,也可以是外连接查询 SELECT 字段列表 FROM 表1 别名A JOIN 表1 别名B ON

40780
您找到你想要的搜索结果了吗?
是的
没有找到

MySQL数据库——多表查询之内连接查询、外连接查询、子查询

1 多表查询 1.1 多表查询概述 多表查询就是从多个表中进行数据的查询操作,语法:select  列名列表 from 表名的列表  where......1.2 多表查询的分类 1.2.1 内连接查询 1)隐式内连接:使用where条件来消除无用的数据; -- 查询所有员工信息和对应的部门信息 SELECT *FROM emp,dept WHERE emp...`id`; 3)内连接查询注意事项: 从哪些表查询; 条件是什么; 查询哪些字段; 1.2.2 外连接查询 1)左外连接:查询的是左表所有的数据及其交集部分。...2)右外连接:查询的是右表所有的数据及其交集部分。...语法:select 字段列表 from 表1 right [outer] join 表2 on 条件 1.2.3 子查询 【概念】:子查询就是查询嵌套查询,称嵌套查询为子查询。

11.7K10

数据库-多表查询-连接查询

数据库-多表查询-连接查询 同时查询多张表获取到需要的数据 比如:我们想查询到开发部有多少人,需要将部门表和员工表同时进行查询 多表查询的分类: 准备数据 -- 创建部门表 create table...-- 只查询一张表不能查询出员工名字和部门名字,需要使用多表操作 select * from emp, dept; 完成多表操作的两种方式: 表连接 子查询 1....外连接Mysql支持:左外连接 、右外连接) 外连接分类 左外连接 左表中所有的记录都出现在结果,并上右表与之对应的部分, 如果右表没有匹配的记录,使用NULL填充 右外连接 右表中所有的记录都出现在结果...使用右外连接查询: 基于右连接查询,不管 emp 的数据有没有关联 dept_id, 也可以查询出右表的所有数据 mysql> select * from dept d right join emp...全外连接查询 full(Mysql不支持,Oracle支持,了解就可以) 在上面的操作,我们已经执行了 左外连接 和 右外连接。那么如果我们想要两张表的所有数据同时查询出来呢?

13.5K20

数据库_mysql多表操作

多表操作 实际开发,一个项目通常需要很多张表才能完成。例如:一个商城项目就需要分类表(category)、商品表(products)、订单表(orders)等多张表。...且这些表的数据之间存在一定的关系,接下来我们将在单表的基础上,一起学习多表方面的知识。 ?...l 多对多关系: n 常见实例:学生和课程、用户和角色 n 多对多关系建表原则:需要创建第三张表,中间表至少两个字段,这两个字段分别作为外键指向各自一方的主键. ?...l 一对一关系:(了解) n 在实际的开发应用不多.因为一对一可以创建成一张表. n 两种建表原则: u 外键唯一:主表的主键和从表的外键(唯一),形成主外键关系,外键唯一unique。...INSERT INTO products (pid,pname) VALUES('p003','商品名称'); #2 向订单表添加数据 INSERT INTO orders (oid ,totalprice

2.2K80

MySQL数据库多表关系与多表联合查询

目录 MySQL多表关系 一对一 一对多 多对多 MySQL外键约束 创建外键 数据插入 删除 多表联合查询 交叉连接查询 内连接查询 外连接查询 子查询关键字 自关联 MySQL多表关系 MySQL...添加主表数据 -- 注意必须先给主表添加数据 添加从表数据 -- 注意给从表添加数据时,外键列的值不能随便写,必须依赖主表的主键列 删除 主表的数据被从表依赖时,不能删除,否则可以删除 从表的数据可以随便删除 多表联合查询...交叉连接查询 • 交叉连接查询返回被连接的两个表所有数据行的笛卡尔积 • 笛卡尔积 可以理解为一张表的每一行去和另外一张表的任意一行进行匹配...ALL表示指定列的值必须要大于子查询集的每一个值,即必须要大于子查询集的最大值;如果是小于号即小于子查询集的最小值。同理可以推出其它的比较运算符的情况。...•表示制定列的值要大于子查询的任意一个值,即必须要大于子查询集中的最小值。同理可以推出其它的比较运算符的情况。

2.7K20

MySQL数据库多表关系与多表联合查询

​​目录MySQL多表关系一对一一对多多对多MySQL外键约束创建外键数据插入删除多表联合查询交叉连接查询内连接查询外连接查询子查询关键字自关联MySQL多表关系MySQL表与表之间的三种关系一对多关系...数据插入添加主表数据 -- 注意必须先给主表添加数据添加从表数据 -- 注意给从表添加数据时,外键列的值不能随便写,必须依赖主表的主键列删除主表的数据被从表依赖时,不能删除,否则可以删除从表的数据可以随便删除多表联合查询​编辑...交叉连接查询 •交叉连接查询返回被连接的两个表所有数据行的笛卡尔积 •笛卡尔积可以理解为一张表的每一行去和另外一张表的任意一行进行匹配 •假如A表有m行数据,B表有n行数据,则返回m*n行数据 •笛卡尔积会产生很多冗余的数据...ALL表示指定列的值必须要大于子查询集的每一个值,即必须要大于子查询集的最大值;如果是小于号即小于子查询集的最小值。同理可以推出其它的比较运算符的情况。...•表示制定列的值要大于子查询的任意一个值,即必须要大于子查询集中的最小值。同理可以推出其它的比较运算符的情况。

2.9K30

多表连接查询

连接查询是关系数据库中最主要的查询,主要包括内连接、外连接和交叉连接等。通过连接运算符可以实现多个表查询。连接是关系数据库模型的主要特点,也是它区别于其它类型数据库管理系统的一个标志。...在关系数据库管理系统,表建立时各数据之间的关系不必确定,常把一个实体的所有信息存放在一个表。当检索数据时,通过连接操作查询出存放在多个表的不同实体的信息。...一、多表连接查询概述 1.1、什么是多表查询 连接是在多个表之间通过一定的连接条件,使表之间发生关联,进而能从多个表之间获取数据。...所以这就是我们的多表查询。 1.2、多表查询的作用 比如: 我们想查询员工A的名字和他所在的部门的名字,则需要使用多表查询。 那么我们使用一条 SQL 语句查询多张表,因为查询结果在多张不同的表。...确认查询的数据库表 确认数据库连接条件 确认数据库表查询条件 确认数据库表显示字段 三、左/右连接 3.1、左连接 使用 left outer join…on,outer 可以省略

1.4K20

一文搞定MySQL多表查询的表连接(join)

多表连接的结果通过三个属性决定 方向性:在外连接写在前边的表为左表、写在后边的表为右表。 主附关系:主表要出所有的数据范围,附表与主表无匹配项时标记为NULL,内连接时无主附表之分。...对应关系:关键字段中有重复值的表为多表,没有重复值的表为一表。 表对应关系 一对一关系 在一对一关系,A 表的一行最多只能匹配于 B 表的一行,反之亦然。...join)、全连接(full join) MySQL连接(inner join)、左连接(left join)、右连接(right join) Power BI 内连接、左连接、右连接、全连接、左反连接...没有WHERE 子句,第一个表的每个行将与第二个表的每个行配对,而不管它们逻辑上是否可以配在一起。 一表作为主表可以保证维度的完整性,多表作为主表可以保证度量的准确性。...度量字段通常存在于多表,因此通常情况下可以将多表作为主表进行外连接

14.8K20

Mysql数据库-多表查询案例

Mysql数据库-多表查询案例 我们在公司开发,根据不同的业务需求往往需要通过2张及以上的表中去查询需要的数据。所以我们有必要学习2张及以上的表的查询。其实不管是几张表的查询,都是有规律可循的。...确定表连接条件 e.job_id=j.id and e.dept_id=d.id and e.salary between s.losalary and hisalary SELECT * FROM...JOIN salarygrade s ON e.job_id=j.id AND e.dept_id=d.id AND e.salary BETWEEN s.losalary AND hisalary; 多表查询规律总结...不管我们查询几张表,表连接查询会产出笛卡尔积,我们需要消除笛卡尔积,拿到正确的数据。...(条件数量=表的数量-1),每张表都要参与进来 多表连接查询步骤:3.1. 确定要查询哪些表 3.2. 确定表连接条件 3.3. 确定查询字段 2.4 练习4 查询经理的信息。

4.6K20

MySQL数据库多表查询

SELECT 子查询 子查询( subquery)即嵌套查询 ,嵌套在其他查询的查询。...count(*) from ArticleDetail where ArticleDetail.ar_id=Article.ar_id) as '文章数目' from Article; SELECT 多表查询...读取ArticleDetail表中所有文章(title)在Article表对应的类型,作者 select ArticleDetail.title,ArticleDetail.reade_times,Article.type...表名称 ORDER BY 列名称; SELECT 列名称 FROM 表名称 UNION ALL SELECT 列名称 FROM 表名称 ORDER BY 列名称; UNION 语句:用于将不同表相同列查询的数据展示出来...;(不包括重复数据) UNION ALL 语句:用于将不同表相同列查询的数据展示出来;(包括重复数据) 列出Author表中和Article中所有不同的作者名:每个列出现一次 select name

4.3K20

数据库MySQL-多表查询

1.2 多表查询 1.2.1 内连接 规则:返回两个表的公共记录 语法: -- 语法一 select * from 表1 inner join 表2 on 表1.公共字段=表2.公共字段 -- 语法二...-----+------------+---------+--------+-------------+---------+ 5 rows in set (0.00 sec) 多学一招: -- 1、内连接...join stumarks; -- 交叉连接连接表达式与内连接是一样的 mysql> select * from stuinfo cross join stumarks on stuinfo.stuno...1.2.5 自然连接 自动判断条件连接,判断的条件是依据同名字段 1、自然内连接(natural join) mysql> select * from stuinfo natural join stumarks...2、如果没有同名字段就返回笛卡尔积 3、同名的连接字段只显示一个,并且将该字段放在最前面 1.2.6 using using用来指定连接字段 mysql> select * from stuinfo

10.4K10

mysql数据库查询数据的语句怎么写_mysql数据库多表查询

命令:mysql>select id, Sum(score) from result group by id; 多表查询 一、等值查询 现在有两个表: 现在要查询年龄小于20岁学生的不及格成绩...from stu,result where stu.id = result.id and age < 20 and score < 60; 它的查询如下图所示: 可见等值查询效率太低 二、连接查询...1、外连接查询 (1)左外连接查询 假设我们依旧使用的是上面的两个表,任然查询年龄小于20岁学生的不及格成绩 我们利用左外连接查询,先将学生表中所有年龄小于20岁的学生取出来,再在成绩表中将所有成绩小于...如果存在左表过滤出来的数据,右表没有匹配上,这样的话右表就会出现NULL; (2)右外连接查询 select a.id,score from (select id,age from stu where...(3)全外连接查询 结合了左外连接和右外连接,使得左表和右表的数据都存在。

29.8K20

jspJDBC连接MySQL数据库

前言:在进行网页制作时,难免会有数据库的使用,今天来讲一下jsp利用JDBC连接MySQL数据库::: 文章目录: 一.JDBC: 二.连接数据库: 1.需要的包: 2.加载驱动: 3.连接数据库:...一.JDBC: JDBC:Java数据库连接(Java Database Connectivity,简称JDBC)是Java语言中用来规范客户端程序如何来访问数据库的应用程序接口,提供了诸如查询和更新数据库数据的方法...(——简介摘自JDBC–百度百科) 二.连接数据库: 注:本案例运用到的数据库版本和驱动版本为: 图片 1.需要的包: <%@ page language="java" contentType=...驱动 Class.forName("com.mysql.cj.jdbc.Driver"); 3.连接数据库: String url = "jdbc:mysql://localhost:3306/demon..."; //数据库用户密码 Connection conn = DriverManager.getConnection(url, username, password); //连接状态 ---- 这样就可以连接数据库

8.7K20

数据库-MySQL基础(9)-多表关系

目录 概述 1、一对多 2、多对多 3、一对一 多表查询概述 多表查询分类 1、连接查询 2、子查询 ---- 概述 项目开发,在进行数据库表结构关系设计时,会根据业务需求及业务模块之间的关系,分析设计表结构...varchar(10) comment '课程名称' )comment '课程表'; insert into course values (null,'Java'),(null,'PHP'),(null,'MySQL...杭州师范大学',3), (null,'本科','应用数学','阳泉第一小学','阳泉区第一学','清华大学' ,4); ---- 多表查询概述 概述:指从多张表查询数据 笛卡尔积:笛卡尔积是指在数学...(在多表查询,需要消除无效的迪卡尔积)  案例: 使用上篇文章所用的表格emp和demp emp表  dept表  输入 --多表查询--笛卡尔积 select * from emp,dept...; 后表会出现这中情况  解决方案 select * from emp,dept where emp.dept_id = dept.id; ---- 多表查询分类 1、连接查询     内连接:相当于查询

1K20

数据库MySQL进阶八、多表查询

数据库MySQL进阶八、多表查询 MySQL多表查询 一 使用SELECT子句进行多表查询 SELECT 字段名 FROM 表1,表2 … WHERE 表1.字段 = 表2.字段 AND 其它查询条件...以两张表的id字段信息相同作为条件建立两表关联,但在实际开发不应该这样使用,最好用主外键约束来实现 二 使用表的别名进行多表查询 如:SELECT a.id,a.name,a.address,b.math...:把查询结果作为WHERE子句的查询条件即称为内连接 五 复杂的嵌套查询 多表之间的嵌套查询可以通过谓词IN实现,语法格式如下: test_expression[NOT] IN{ subquery...六 嵌套查询在查询统计的应用 实现多表查询时,可以同时使用谓词ANY、SOME、ALL,这些谓词被称为定量比较谓词,可以和比较运算符联合使用,判断是否全部返回值都满足搜索条件.SOME和ANY谓词是存在量的...INNER JOIN … ON 语句将两表连接起来,实现查询 十五 使用外连接实现多表联合查询 (1)LEFT OUTER JOIN表示表之间通过左连接方式相互连接,也可简写成LEFT JOIN,它是以左侧的表为基准故称左连接

2.3K40

数据库-MySQL-多表查询(总结)

目录 前言 多表查询概述 多表查询分类 1、连接查询 2、子查询  内连接连接查询语法  案例演示 外连接连接查询的语法 案例演示   联合查询-union,union all 子查询 概念 分类...标量子查询 自连接连接查询语法 案例演示 子查询 列子查询 行子查询 表子查询 ---- 前言 项目开发,在进行数据库表结构关系设计时,会根据业务需求及业务模块之间的关系,分析设计表结构,由于业务之间相互关联...杭州师范大学',3), (null,'本科','应用数学','阳泉第一小学','阳泉区第一学','清华大学' ,4); ---- 多表查询概述 概述:指从多张表查询数据 笛卡尔积:笛卡尔积是指在数学...(在多表查询,需要消除无效的迪卡尔积)  案例: 使用上篇文章所用的表格emp和demp emp表  dept表  输入 --多表查询--笛卡尔积 select * from emp,dept...; 后表会出现这中情况  解决方案 select * from emp,dept where emp.dept_id = dept.id; ---- 多表查询分类 1、连接查询     内连接:相当于查询

82030
领券