SQL语句实现多表查询

吾爱主题 阅读:146 2024-04-01 23:20:05 评论:0
目录
  • 基本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多表查询内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文地址:https://blog.csdn.net/m0_48958478/article/details/125723039

可以去百度分享获取分享代码输入这里。
声明

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

【腾讯云】云服务器产品特惠热卖中
搜索
标签列表
    关注我们

    了解等多精彩内容