免费网站软件下载,一级造价工程师报名网站,淘客网站难做吗,国内的c2c网站有哪些目录
一、前言
二、SQL写法
1、sql获取某一条数据中的前一条和后一条
2、实现like多个值的查询#xff08;Oracle和dm支持#xff0c;MySQL未试过#xff09;
3、start with connect by prior 使用方法
4、用hextoraw解决select、update、delete语句执行慢
5、ORA-00…目录
一、前言
二、SQL写法
1、sql获取某一条数据中的前一条和后一条
2、实现like多个值的查询Oracle和dm支持MySQL未试过
3、start with connect by prior 使用方法
4、用hextoraw解决select、update、delete语句执行慢
5、ORA-00979不是GROUP BY表达式
6、merge语句
三、与MySQL写法区别
1、Oracle与MySQL的SQL区别系列
2、MySQL系列oracle和mysql批量插入的区别 一、前言 平时写SQL的时候需要写的SQL千奇百怪从各个帖子学习之后记录下曾经用到的一些用法方便以后在用到查找找的时候真费力呀。 二、SQL写法
1、sql获取某一条数据中的前一条和后一条 在SQL查询中使用LEAD和LAG函数这两个窗口函数用于获取行的前后值通过ORDERBY对ORDER_COL进行排序。提供了一个示例展示了如何在特定表TABLE_NAME中应用这些函数来过滤数据。
SELECT *
FROM (SELECT ID, NAME, LEAD(ID) OVER(ORDER BY ORDER_COL) NEXT_ID, LAG(ID) OVER(ORDER BY ORDER_COL) PREV_IDFROM TABLE_NAME
)
WHERE ID
其中LEAD和LAG函数的参数可以是其他值.
说明
1)、关于LEAD和LAG函数可以参考sql中的窗口函数leadlag
2)、该写法参考网上的一种写法可以使用
2、实现like多个值的查询Oracle和dm支持MySQL未试过
1regexp_like (字段名,(条件1|条件2|条件3|条件4))
regexp_like (字段名, #{参数})
if testuserAccount ! null and userAccount ! and regexp_like(OTHER_SPECIALITY_CODE,${userAccount})
/if
或者
if testotherSpecialityCodeList ! null and otherSpecialityCodeList.size() 0orforeach collectionotherSpecialityCodeList indexindex itemitemopen( separatoror close)regexp_like(OTHER_SPECIALITY_CODE,${item})/foreach
/if
2同一字段 like 多值 可区分 单向模糊 和 双向模糊Oracle和dm未试过MySQL支持
双向模糊查询
SELECT * from aaaaaaa where name like %张三% or name like %李四% or name like %王五%
或
SELECT * from aaaaaaa where name REGEXP 张三|李四|王五单项模糊查询
SELECT * from aaaaaaa where name like %张三 or name like %李四 or name like %王五
或
SELECT * from aaaaaaa where name REGEXP ^张三|^李四|^王五3、start with connect by prior 使用方法
参考Oracle系列start with connect by prior 使用方法
4、用hextoraw解决select、update、delete语句执行慢
参考Oracle系列用hextoraw解决select、update、delete语句执行慢
5、ORA-00979不是GROUP BY表达式
参考Oracle系列ORA-00979不是GROUP BY表达式
6、merge语句
参考Oracle系列oracle批量merge into来实现批量新增并在新增的同时更新满足条件的数据
参考Oracle系列MERGE语句
7、DECODE函数实现按着指定字符串顺序进行排序 DECODE函数是Oracle数据库中的条件表达式函数用于执行条件判断并返回对应的结果。它的基本语法如下 DECODE(expr, search1, result1, search2, result2, ..., default) expr要比较的表达式或列。search1, search2, ...要比较的值。result1, result2, ...如果expr等于相应的search值则返回相应的result值。default如果没有找到匹配项则返回default值。 详细学习参考博客Oracle中decode函数详解
排序查询结果按着sortedList 定义的集合顺序进行排序如果UNIT_CODE相同按着创建时间排序。
ListString sortedList new ArrayList();
sortedList.add(A);
sortedList.add(C);
sortedList.add(D);
sortedList.add(W);
sortedList.add(F);
order by DECODE(UNIT_CODE,
foreach collectionsortedList indexindex itemitem separator,#{item},#{index}
/foreach
,9999),CREATE_TIME desc 三、与MySQL写法区别
1、Oracle与MySQL的SQL区别系列
参考Oracle与MySQL的SQL区别系列
2、MySQL系列oracle和mysql批量插入的区别
参考MySQL系列oracle和mysql批量插入的区别 未完待续。。。