SQL语句实现多表查询

 更新时间:2022年07月19日 15:31:39   作者:一顿吃不饱  
这篇文章主要介绍了SQL语句实现多表查询,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参一下下面文章详细内容

基本sql语句

SELECT <目标字段> FROM <数据库表> WHERE <查询条件> GROUP BY <分组依据> ORDER BY <排列依据>

多表查询

内连接 :返回满足连接条件的数据

格式:SELECT <目标字段> FROM <INNER JOIN+表名+ON+连接条件> WHERE <查询条件>

注意:理清表与表之间的关系,从哪些表中查出哪些数据,表与表之间的连接条件是什么

例一:双表查询

例二:多表查询

a  sys_user       user_name => user_id dept_id
b  sys_user_role  user_id   => role_id
c  sys_role       role_id   => role_name
d  sys_role_dept  role_id   => dept_id
e  sys_dept       dept_id   => dept_name parent_id dept_name
f  sys_dept       parent_id => dept_name
SELECT 
	a.user_name,
	a.user_id,
	a.dept_id,
	b.role_id,
	c.role_name,
	e.dept_name,
	f.dept_name
FROM
	sys_user AS a
	INNER JOIN  sys_user_role AS b  ON b.user_id = a.user_id
    INNER JOIN  sys_role AS c       ON c.role_id = b.role_id
    INNER JOIN  sys_dept AS e       ON e.dept_id = a.dept_id
	INNER JOIN  sys_dept AS f       ON f.dept_id = e.parent_id
WHERE
	a.user_name = 'zjzsqxyf01'

外连接:外连接不只列出与连接条件相匹配的行,而是列出左表(左外连接时)、右表(右外连接时)或两个表(全外连接时)中所有符合搜索条件的数据行

(1)左连接:返回左表中的所有数据

格式:SELECT <目标字段> FROM <LEFT JOIN+表名+ON+连接条件> WHERE <查询条件>

(2)右连接:返回右表中的所有数据

格式:SELECT <目标字段> FROM <RIGHT JOIN+表名+ON+连接条件> WHERE <查询条件>

(3)全连接:在等值连接的基础上将左表和右表的未匹配数据都加上

格式:SELECT <目标字段> FROM <FULL JOIN+表名+ON+连接条件> WHERE <查询条件>

自然连接:以两个表具有相同的字段的所有列为基础,返回两个表中满足查询条件的数据

到此这篇关于SQL语句实现多表查询的文章就介绍到这了,更多相关SQL多表查询内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • MySql存储表情报错的排查解决

    MySql存储表情报错的排查解决

    随着互联网的发展,产生了许多新类型的字符,例如emoji这种类型的符号,也就是我们通常在聊天时发的小黄脸表情,下面这篇文章主要给大家介绍了关于MySql存储表情报错的排查解决,需要的朋友可以参考下
    2022-07-07
  • MySql查询某个时间段内的数据实例(前一周、前三个月、前一年等)

    MySql查询某个时间段内的数据实例(前一周、前三个月、前一年等)

    在实际工作中需要整理一份时间在规定时间前后的统计表,下面这篇文章主要给大家介绍了关于MySql查询某个时间段内的数据的相关资料,包括前一周、前三个月、前一年等,需要的朋友可以参考下
    2022-10-10
  • 验证mysql是否安装成功的方法

    验证mysql是否安装成功的方法

    在本篇文章里小编给大家分享的是关于验证mysql是否安装成功的方法,需要的朋友们可以学习下。
    2020-06-06
  • MySQL如何快速修改表的表结构

    MySQL如何快速修改表的表结构

    这篇文章主要介绍了MySQL如何快速修改表的表结构,帮助大家更好的理解和学习MySQL,感兴趣的朋友可以了解下
    2020-08-08
  • MySQL中JSON字段数据类型详解

    MySQL中JSON字段数据类型详解

    JSON我相信大家都已经很熟悉了,但在 MySQL中,直至 5.7 版本中,才正式引入 JSON数据类型,下面这篇文章主要给大家介绍了关于MySQL中JSON字段数据类型的相关资料,需要的朋友可以参考下
    2022-06-06
  • MySQL中的聚簇索引、非聚簇索引、联合索引和唯一索引详细介绍

    MySQL中的聚簇索引、非聚簇索引、联合索引和唯一索引详细介绍

    本文主要介绍了MySQL的索引类型,根据索引的存储方式来划分,索引可以分为聚簇索引和非聚簇索引。聚簇索引的特点是叶子节点包含了完整的记录行,而非聚簇索引的叶子节点只有所以字段和主键ID,感兴趣的同学可以阅读本文
    2023-04-04
  • 基于Php mysql存储过程的详解

    基于Php mysql存储过程的详解

    本篇文章是对Php中的mysql存储过程进行了详细的分析介绍,需要的朋友参考下
    2013-06-06
  • MySQL实现replace函数的几种实用场景

    MySQL实现replace函数的几种实用场景

    这篇文章主要介绍了MySQL实现replace函数的几种实用场景,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-02-02
  • 解读SQL中GROUP BY和HAVING子句中使用NULL条件问题

    解读SQL中GROUP BY和HAVING子句中使用NULL条件问题

    在使用SQL进行数据查询时,可能会遇到查询结果为空的情况,这通常与GROUP BY和HAVING子句的使用有关,尤其是在处理包含NULL值的字段时,当使用GROUP BY进行数据分组,并在HAVING子句中直接判断字段是否为NULL时
    2024-10-10
  • MySQL中ADDDATE()函数的使用教程

    MySQL中ADDDATE()函数的使用教程

    这篇文章主要介绍了MySQL中ADDDATE()函数的使用教程,是MySQL入门学习中的基础知识,需要的朋友可以参考下
    2015-05-05

最新评论