zl程序教程

您现在的位置是:首页 >  数据库

当前栏目

SQL语句实现多表查询

SQL 实现 查询 语句 多表
2023-06-13 09:19:42 时间

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、ORACLE、SQLSERVER、MongoDB、PostgreSQL 、程序问题
服务方式:远程服务、电话支持、现场服务,沟通指定方式服务
技术标签:数据恢复、安装配置、数据迁移、集群容灾、异常处理、其它问题

本站部分文章参考或来源于网络,如有侵权请联系站长。
数据库远程运维 SQL语句实现多表查询