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

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

目录 MySQL多表关系 一对一 一对多 多对多 MySQL外键约束 创建外键 数据插入 删除 多表联合查询 交叉连接查询 内连接查询 外连接查询查询关键字 自关联 MySQL多表关系 MySQL...,必须依赖主表主键列 删除 主表数据被从表依赖时,不能删除,否则可以删除 从表数据可以随便删除 多表联合查询 交叉连接查询 • 交叉连接查询返回被连接两个表所有数据行笛卡尔积...子查询就是指在一个完整查询语句之中,嵌套若干个不同功能查询,从而一起完成复杂查询一种编写形式,通俗一点就是包含select嵌套查询。...ALL表示指定列中值必须要大于子查询每一个值,即必须要大于子查询最大值;如果是小于号即小于子查询最小值。同理可以推出其它比较运算符情况。...•表示制定列中值要大于子查询任意一个值,即必须要大于子查询集中最小值。同理可以推出其它比较运算符情况。

2.7K20

Mysql数据库-多表查询案例

Mysql数据库-多表查询案例 我们在公司开发中,根据不同业务需求往往需要通过2张及以上表中去查询需要数据。所以我们有必要学习2张及以上查询。其实不管是几张表查询,都是有规律可循。...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 查询经理信息。...salarygrade s ON e.job_id=j.id AND e.dept_id=d.id AND e.salary BETWEEN s.losalary AND hisalary; 额外条件:只需要查询经理信息

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

MySQL数据库多表查询

SELECT 子查询查询( subquery)即嵌套查询 ,嵌套在其他查询查询。...查询粉丝数大于400用户作者QQ号 select name,au_id,qq from Author where au_id in(select au_id from Article where...=Article.ar_id) as '文章数目' from Article; SELECT 多表查询 查询每篇文章阅读次数,所属类型,作者 select ArticleDetail.title,ArticleDetail.reade_times...,联结表越多,性能下降越厉害 查询阅读次数大于400文章标题,作者QQ号(使用表别名) select AD.title,AD.reade_times,Au.name,Au.qq from ArticleDetail...;(不包括重复数据) UNION ALL 语句:用于将不同表中相同列中查询数据展示出来;(包括重复数据) 列出Author表中和Article中所有不同作者名:每个列出现一次 select name

4.3K20

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

​​目录MySQL多表关系一对一一对多多对多MySQL外键约束创建外键数据插入删除多表联合查询交叉连接查询内连接查询外连接查询查询关键字自关联MySQL多表关系MySQL表与表之间三种关系一对多关系...在多一方建立外外键指向一一方​编辑多对多 下表为多对多关系,由下表可知多对多关系中间表至少需要2个外键​编辑 MySQL外键约束创建外键 格式: constraint foreign...,必须依赖主表主键列删除主表数据被从表依赖时,不能删除,否则可以删除从表数据可以随便删除多表联合查询​编辑 交叉连接查询 •交叉连接查询返回被连接两个表所有数据行笛卡尔积 •笛卡尔积可以理解为一张表每一行去和另外一张表任意一行进行匹配...,嵌套若干个不同功能查询,从而一起完成复杂查询一种编写形式,通俗一点就是包含select嵌套查询。...ALL表示指定列中值必须要大于子查询每一个值,即必须要大于子查询最大值;如果是小于号即小于子查询最小值。同理可以推出其它比较运算符情况。

2.9K30

数据库MySQL-多表查询

1.2 多表查询 1.2.1 内连接 规则:返回两个表公共记录 语法: -- 语法一 select * from 表1 inner join 表2 on 表1.公共字段=表2.公共字段 -- 语法二...1.2.3 右外连接 规则:以右边表为准,左边如果没有对应记录用null显示 语法: select * from 表1 right join 表2 on 表1.公共字段=表2.公共字段 例题: mysql...join stumarks; -- 交叉连接有连接表达式与内连接是一样 mysql> select * from stuinfo cross join stumarks on stuinfo.stuno...2、如果没有同名字段就返回笛卡尔积 3、同名连接字段只显示一个,并且将该字段放在最前面 1.2.6 using using用来指定连接字段 mysql> select * from stuinfo...,优化规则和自然连接是一样; 1.2.7 练习 1、显示地区及每个地区参加笔试的人数,并按人数降序排列 -- 第一步: 显示地区及每个地区参加笔试的人数 mysql> select stuaddress

10.4K10

mysql 多表查询

,以两张表id字段信息相同作为条件建立两表关联,但在实际开发中不应该这样使用,最好用主外键约束来实现 二、使用表别名进行多表查询 如:SELECT a.id,a.name,a.address,b.math...WHERE子句查询条件即称为内连接 五、复杂嵌套查询 多表之间嵌套查询可以通过谓词IN实现,语法格式如下: test_expression[NOT] IN{ subquery } 参数说明...:test_expression指SQL表达式,subquery包含某结果集查询 多表嵌套查询原理:无论是多少张表进行嵌套,表与表之间一定存在某种关联,通过WHERE子句建立此种关联实现查询 六...、嵌套查询查询统计中应用 实现多表查询时,可以同时使用谓词ANY、SOME、ALL,这些谓词被称为定量比较谓词,可以和比较运算符联合使用,判断是否全部返回值都满足搜索条件.SOME和ANY谓词是存在量...,这样可以方便用户在使用mysql_fetch_array()函数时为表项赋值,如 SELECT (SELECT AVG(chinese) FROM tb_demo071) AS yuwen ,(SELECT

5.6K10

MySQL 多表查询

# MySQL 多表查询 mysql多表查询 问题引出(重点,难点) 说明 多表查询练习 自连接 mysql表子查询 什么是子查询 单行子查询 多行子查询 在多行子查询中使用 all 操作符 在多行子查询中使用...any 操作符 多列子查询 在 from 子句中使用子查询 表复制 自我复制数据(蠕虫复制) 合并查询 介绍 外连接 课堂练习 # mysql多表查询 # 问题引出(重点,难点) # 说明 多表查询是指基于两个和两个以上查询....在实际应用中,查询单个表可能不能满足你需求. # 多表查询练习 -- 多表查询 -- 显示雇员名,雇员工资及所在部门名字【笛卡尔积】 SELECT * FROM salgrade SELECT...,返回结果[含有两张表所有列] (2)一共返回记录数第一张表行数*第二张表行数 (3)这样多表查询默认处理返回结果,称为【笛卡尔积】 (4)解决这个多表关键就是要写出正确过滤条件...,如果没有成绩,也要显示该人姓名和id号,成绩显示为空) -- 外连接 -- 比如:列出部门名称和这些部门员工名称和工作,同时要求 显示出那些没有员工部门 -- 使用我们学习过多表查询sql

4K20

Mysql多表查询

前言 学习SQL多表查询,本文就介绍MySQL数据库中联表查询方法 一、MySQL中有几种联表查询方法?...内连接:inner join 或 join 左外连接:left join 右外连接:right join 全连接:Mysql是不支持全连接,可以利用union合并结果集实现全连接效果 等值连接:where...就是多张表所有数据,但是注意"它们交集"不能重复出现。...table_2 t2 where t1.id=t2.id;   和内连接一样是取交集  6、笛卡尔积 select * from table_1,table_2; 实际不会用笛卡尔积,通常是配合条件查询出有效数据...,比如:等值连接查询 总结 以上就是今天要讲内容,本文仅仅介绍了常用6种表连接方式,在SQL中还有一些方式,比如:条件不一定得是”等值“,也可以是范围。

18130

MySQL多表查询

多表查询如果不加任何条件,得到结果称为笛卡尔积。 例如,查找雇员名、雇员工资以及部门所在名字。...自连接 自连接是指在同一张表连接查询 显示员工FORD上级领导名字 子查询查询是指嵌入在其他sql语句中select语句,也叫嵌套查询。...单行子查询:子查询查询结果只有一行 显示和SMITH同一部门员工 多行子查询(in ,all, any):返回多条记录查询 查询和10好部门工作相同官员名字、工作、工资、部门号,但是不包括...10号自己信息 显示工资比部门编号为30所有员工工资高员工姓名、工资和部门号 显示工资比部门编号为30任意员工工资高员工姓名、工资和部门号 多列子查询查询返回多个列数据查询语句...3.显示每个部门信息(部门名、编号、地址)和人员数量 这里有两种方法可以使用,但是经验证,当数据非常多时候from子查询效率是高于多表查询

3.1K30

MySQL多表查询

浅记sql中多表查询相关语法 笛卡尔积 单表查询:select * from table1; 多表查询:select *from table1,table2; id name age status...女 3 禁止 2 李四 12 1 女 2 受限 2 李四 12 1 女 1 正常 3 王五 1 1 男 3 禁止 3 王五 1 1 男 2 受限 3 王五 1 1 男 1 正常 直接采用这种方法进行多表查询...在多表查询时,需要消掉无效笛卡尔积。...这些查询方式区别在于子查询返回值格式,限制了可用运算符: 标量子查询:子查询结果为单个值。 列子查询:子查询结果为一列。 行子查询:子查询结果为一行。 表子查询:子查询结果为多行多列。...根据姓名查询状态id 根据上一步获取到状态id查询状态描述 列子查询 标量子查询返回结果是单个值,列子查询返回结果是多个值。

20420

MySQL多表查询

MySQL多表查询 交叉连接查询 语法:selectfrom 表1 cross join 表2; 或  selectfrom 表1,表2; 这样查询结果为两个表中所有数据行乘积即笛卡尔积...内连接查询: 注意:要查询表,查询条件,查询字段。...复合条件连接查询 定义:复合条件连接查询就是在连接查询过程中,通过添加过滤条件来限制查询结果,使查询结果更加精确。 子查询(嵌套查询) 定义:子查询是指一个查询语句嵌套在另一个查询语句内部查询。...在执行查询语句时,首先会执行子查询语句,然后将返回结果作为外层查询过滤条件。...IN :用于判断一个给定值是否存在于子查询结果集中。 EXISTS :用于判断子查询结果集是否为空。若子查询结果集不为空,则返回 TRUE;否则返回 FALSE。

3.2K10

mysql多表查询分类

多表查询分类 分类1:等值连接 vs 非等值连接 1....阿里开发规范: 【强制】对于数据库中表记录查询和变更,只要涉及多个表,都需要在列名前加表别名(或 表名)进行限定。...说明:对多表进行查询记录、更新记录、删除记录时,如果对操作列没有限定表别名(或表名),并且操作列在多个表中存在时,就会抛异常。...正例:select t1.name from table_first as t1 , table_second as t2 where t1.id=t2.id; 反例:在某业务中,由于多表关联查询语句没有加表别名...(或表名)限制,正常运行两年后,最近在 某个表中增加一个同名字段,在预发布环境做数据库变更后,线上查询语句出现出 1052 异常:Column 'name' in field list is ambiguous

2.3K40

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

目录 前言 多表查询概述 多表查询分类 1、连接查询 2、子查询  内连接 内连接查询语法  案例演示 外连接 外连接查询语法 案例演示   联合查询-union,union all 子查询 概念 分类...标量子查询 自连接 自连接查询语法 案例演示 子查询 列子查询 行子查询 表子查询 ---- 前言 项目开发中,在进行数据库表结构关系设计时,会根据业务需求及业务模块之间关系,分析设计表结构,由于业务之间相互关联...varchar(10) comment '课程名称' )comment '课程表'; insert into course values (null,'Java'),(null,'PHP'),(null,'MySQL...(在多表查询中,需要消除无效迪卡尔积)  案例: 使用上篇文章所用表格emp和demp emp表  dept表  输入 --多表查询--笛卡尔积 select * from emp,dept...; 后表会出现这中情况  解决方案 select * from emp,dept where emp.dept_id = dept.id; ---- 多表查询分类 1、连接查询     内连接:相当于查询

82330

数据库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 } 参数说明:...test_expression指SQL表达式,subquery包含某结果集查询 多表嵌套查询原理:无论是多少张表进行嵌套,表与表之间一定存在某种关联,通过WHERE子句建立此种关联实现查询 六...嵌套查询查询统计中应用 实现多表查询时,可以同时使用谓词ANY、SOME、ALL,这些谓词被称为定量比较谓词,可以和比较运算符联合使用,判断是否全部返回值都满足搜索条件.SOME和ANY谓词是存在量

2.3K40

MySQL数据库基础(十一):多表查询

多表查询 一、交叉连接(了解) 它是所有连接基础,其功能就是将表1和表2中每一条数据进行连接。...* from students, classes; 二、内连接 1、连接查询介绍 连接查询可以实现多个表查询,当查询字段数据来自不同表就可以使用连接查询来完成。...连接查询可以分为: 内连接查询 左外连接查询 右外连接查询 2、内连接查询 查询两个表中符合条件共有记录 内连接查询语法格式: select 字段 from 表1 inner join...内连接根据连接查询条件取出两个表 “交集” 三、左外连接 1、左连接查询 以左表为主根据条件查询右表数据,如果根据条件查询右表数据不存在使用null值填充 左连接查询语法格式: select 字段...left join .. on .., on 表示两个表连接查询条件 左连接以左表为主根据条件查询右表数据,右表数据不存在使用null值填充。

9410

Mysql 多表查询详解

Mysql 多表查询详解 一.前言 二.示例 三.注意事项 一.前言 上篇讲到Mysql中关键字执行顺序,只涉及了一张表;实际应用大部分情况下,查询语句都会涉及到多张表格 : 1.1 多表连接有哪些分类...B中所有数据减去 “与A满足同一条件 数据“,然后得到B剩余数据; 2.2.5 full join (mysql不支持,但是可以用 left join union right join代替)...(id为2,3,4三条记录),所以结果如下: 应用场景: 这种场景下得到是满足某一条件公共记录,和独有的记录 2.2.6 full join + is null(mysql不支持,但是可以用...三 注意事项 上面仍然存在遗漏,那就是mysql对sql语句容错问题,即在sql语句不完全符合书写建议情况,mysql会允许这种情况,尽可能地解释它: 3.1 一般cross join后面加上where...,会被解释为交叉连接; 注:sql标准中还有union join和natural inner join,mysql不支持,而且本身也没有多大意义,其结果可以用上面的几种连接方式得到 总结:总结了mysql

2K20

MySQL多表查询操作

MySQL左连接(LEFT JOIN)、右连接(RIGHT JOIN)和内连接(INNER JOIN)是用于连接两个或多个表查询方式。...这些连接方式可以根据指定条件将两个表中数据进行组合,以便在一个查询结果集中显示相关数据。 1....是要查询列名列表,left_table和right_table分别是要连接左表和右表,join_condition是连接条件。...内连接只返回两个表中满足条件记录,不会显示NULL值。内连接可以用于查询两个表中相关数据。特点如下: •内连接只返回左右表中都存在匹配行,不包括任何一方孤立行。...是要查询列名列表,left_table和right_table分别是要连接左表和右表,join_condition是连接条件。

25210

MySQL多表练习、查询以及多表关系

多表 一、多表概述 1. 多表简介 实际开发中,一个项目通常需要很多张表才能完成。例如:一个商城项目就需要分类表(category)、商品表(product)、订单表(orders)等多张表。...且这些表数据之间存在一定关系,接下来我们将在单表基础上,一起学习多表方面的知识。 2....多表创建流程 设计表:设计相关多个表; 创建表并设置主外键关系: 方式一:创建表时设置多张表之间关系; 方式二:创建表之后,再设置表之间关系 3....,category_id) VALUES(3,'商品名称2',9); #5 删除指定分类(分类被商品使用) -- 执行异常 DELETE FROM category WHERE cid = 1; 三、多表查询...案例说明 本案例以一对多关系分类和商品表为例,进行常见几种查询 交叉连接查询 语法:select * from A,B  内连接查询(使用关键字 inner join  -- inner

2.5K20
领券