达梦(DM) SQL查询及联合查询

简介: 继续讲解达梦(DM)数据库SQL查询操作

这里继续讲解DM数据库的Sql查询操作

查询结果排序

为提高查询结果可读性,我们可以对查询结果按照一定顺序排列,或者也可以将列名替换成数字,例如 ORDER BY 1 DESC,意思是按第一列进行升序排序

SELECT*FROM PY_PERIOD_CLAZZ WHERE ROWNUM <5ORDERBY ID DESC;SELECT*FROM PY_PERIOD_CLAZZ WHERE ROWNUM <5ORDERBY1DESC;

执行结果如图

image.png

如果想要进行多列排序的话,可以在 order by 后加两列,并分别标明 ASC, DESC。其中 ASC 表示升序,DESC 表示降序

SELECT*FROM PY_PERIOD_CLAZZ WHERE ROWNUM <5ORDERBY2ASC,1DESC;

执行结果如图

image.png

说明:多列排序,若前面的列有重复,后面的排序才有用。即先通过前面的列将数据分组,再按照后面的列进行排序。

如果想按照客户手机号尾号的顺序排列,缩小查询范围,可以通过如下函数实现子串排序

SELECT USER_NAME AS 姓名, SUBSTR (PHONENUMBER,-4)AS 尾号 FROM SYS_USER WHERE ROWNUM <5ORDERBY2;

查询结果如图

image.png

TRANSLATE 可实现字符替换,语法格式:TRANSLATE(expr,from_string,to_string),from_string 与 to_string 以字符为单位,对应字符逐个替换

SELECT TRANSLATE ('ab你好bcadefg','abcdefg','1234567')AS new_str FROM DUAL;

执行结果如图

image.png

如果 to_string 为空,则直接返回空值

SELECT TRANSLATE ('ab你好bcadefg','abcdefg','')AS new_str FROM DUAL;

执行结果如图

image.png

如果 to_string 对应的位置没有字符,from_string 中列出的字符将会被删除

SELECT TRANSLATE('11ab你好bcadefg','1abcdefg','1')AS new_str FROM DUAL;

查询结果如图

image.png

多表联合查询

使用 union 或者 union all 关键字合并多个结果集时,对应的列数必须一致,列的数据类型必须匹配。当其中一个结果集的列数不满足要求时,可以使用 NULL 或者 空字符串 填充

// 使用 NULL 填充
SELECT USER_ID, USER_NAME FROM SYS_USER WHERE ROWNUM <5UNION ALL
SELECT11,NULLFROM DUAL;

查询结果如图

image.png

// 使用 '' 填充
SELECT USER_ID, USER_NAME FROM SYS_USER WHERE ROWNUM <5UNION ALL
SELECT11,''FROM DUAL;

查询结果如图

image.png

注意:如果存在 order by 子句,必须添加到 union 和 union all 的最后。

union all 用于合并两个结果集,但是会出现重复数据,比如

SELECT*FROM SYS_USER WHERE USER_ID=1OR USER_NAME='若依';

or查询返回一条数据,结果正确

image.png

使用union all 合并结果集的话

SELECT*FROM SYS_USER WHERE USER_ID=1UNION ALL
SELECT*FROM SYS_USER WHERE USER_NAME='若依';

查询结果重复了

image.png

使用union的话就可以了

SELECT*FROM SYS_USER WHERE USER_ID=1UNIONSELECT*FROM SYS_USER WHERE USER_NAME='若依';

查询结果

image.png

说明:使用 union all 替换 or,执行计划更高效,出现重复行时,使用 union 去重。

EXCEPT 获取第一个结果集的数据,然后排除第二个结果集的数据,类似减法运算

CREATETABLE dept ASSELECT dept_id FROM SYS_USER;INSERTINTO dept VALUES(888),(999),(3004); COMMIT;SELECT dept_id FROM dept EXCEPT SELECT dept_id FROM SYS_USER;

查询结果如图

image.png

查询含有 null 值的行时,如果包含 IN、NOT IN 要注意两者的区别。IN 相当于 OR, 而 NOT IN 相当于 AND,比如

SELECT*FROM SYS_USER WHERE user_id IN(1,2,NULL);

查询出数据库的2条数据,

SELECT*FROM SYS_USER WHERE user_id notin(1,2,NULL);

并未查询出数据,因为 NOT IN 的逻辑是 1 AND 2 AND NULL。当 NOT IN 后面跟的子查询返回的列存在 NULL 值,可能得不到正确的结果。

内连接:完全满足连接条件的记录

SELECT*FROM SYS_USER t1,DEPT t2 WHERE t1.DEPT_ID=t2.DEPT_ID;SELECT*FROM SYS_USER t1 JOIN DEPT t2 on(t1.DEPT_ID=t2.DEPT_ID);

查询结果如图

image.png

左外连接:结果不仅包含满足条件的记录,还包含位于左表中不满足条件的记录,此时右表的记录显示为 NULL

SELECT t1.USER_NAME,t2.DEPT_IDFROM SYS_USER t1 LEFT OUTER JOIN DEPT t2 on(t1.DEPT_ID=t2.DEPT_ID);

查询结果如图

image.png

右外连接:结果不仅包含满足条件的记录,还包含位于右表中不满足条件的记录,对应的左表的记录显示为 NULL

SELECT t1.USER_NAME,t2.DEPT_IDFROM SYS_USER t1 RIGHT OUTER JOIN DEPT t2 on(t1.DEPT_ID=t2.DEPT_ID);

查询结果如图

image.png

全外连接:结果不仅包含满足条件的记录,还会包含位于两边表中所有不满足条件的记录,对应的两边表的记录显示为 NULL

SELECT t1.USER_NAME,t2.DEPT_IDFROM SYS_USER t1 FULL OUTER JOIN DEPT t2 on(t1.DEPT_ID=t2.DEPT_ID);

查询结果如图

image.png

自连接:表和自身进行连接,自连接查询至少要对一张表起别名,否则,服务器无法识别要处理的是哪张表。

相关文章
|
1月前
|
SQL
开发指南057-执行SQL返回结果集
业务实践中除了返回实体类外,经常需要通过SQL语句返回结果集
|
9天前
|
SQL 监控 关系型数据库
SQL语句当前及历史信息查询-performance schema的使用
本文介绍了如何使用MySQL的Performance Schema来获取SQL语句的当前和历史执行信息。Performance Schema默认在MySQL 8.0中启用,可以通过查询相关表来获取详细的SQL执行信息,包括当前执行的SQL、历史执行记录和统计汇总信息,从而快速定位和解决性能瓶颈。
|
21天前
|
SQL 存储 缓存
如何优化SQL查询性能?
【10月更文挑战第28天】如何优化SQL查询性能?
74 10
|
15天前
|
SQL 关系型数据库 MySQL
|
29天前
|
SQL 数据库 开发者
功能发布-自定义SQL查询
本期主要为大家介绍ClkLog九月上线的新功能-自定义SQL查询。
|
1月前
|
SQL 移动开发 Oracle
SQL语句实现查询连续六天数据的方法与技巧
在数据库查询中,有时需要筛选出符合特定时间连续性条件的数据记录
|
1月前
|
SQL Java 数据库连接
如何使用`DriverManager.getConnection()`连接数据库,并利用`PreparedStatement`执行参数化查询,有效防止SQL注入。
【10月更文挑战第6天】在代码与逻辑交织的世界中,我从一名数据库新手出发,通过不断探索与实践,最终成为熟练掌握JDBC的开发者。这段旅程充满挑战与惊喜,从建立数据库连接到执行SQL语句,再到理解事务管理和批处理等高级功能,每一步都让我对JDBC有了更深的认识。示例代码展示了如何使用`DriverManager.getConnection()`连接数据库,并利用`PreparedStatement`执行参数化查询,有效防止SQL注入。
98 5
|
1月前
|
SQL 数据挖掘 数据库
SQL查询每秒的数据:技巧、方法与性能优化
id="">SQL查询功能详解 SQL(Structured Query Language,结构化查询语言)是一种专门用于与数据库进行沟通和操作的语言
|
1月前
|
SQL 移动开发 大数据
SQL语句查询连续六天满足条件的记录
在数据库管理和数据分析中,我们经常需要查询符合特定时间范围内连续几天的记录
|
1月前
|
SQL 数据挖掘 关系型数据库
SQL查询次数大于1的记录:高效技巧与方法
在数据库管理中,经常需要统计某些操作的次数,特别是当需要找出哪些记录或值出现的次数超过一定阈值(如大于1次)时
下一篇
无影云桌面