目录
2、实现like多个值的查询(Oracle和dm支持,MySQL未试过)
3、start with connect by prior 使用方法
4、用hextoraw解决select、update、delete语句执行慢
一、前言
平时写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_ID
FROM TABLE_NAME
)
WHERE ID = ''
其中LEAD和LAG函数的参数可以是其他值.
说明:
1)、关于LEAD和LAG函数可以参考:sql中的窗口函数:lead,lag
2)、该写法参考网上的一种写法,可以使用
2、实现like多个值的查询(Oracle和dm支持,MySQL未试过)
1)regexp_like (字段名,'(条件1|条件2|条件3|条件4)')
regexp_like (字段名, #{参数})
<if test="userAccount != null and userAccount != ''">
and regexp_like(OTHER_SPECIALITY_CODE,${userAccount})
</if>
或者
<if test="otherSpecialityCodeList != null and otherSpecialityCodeList.size() > 0">
or
<foreach collection="otherSpecialityCodeList" index="index" item="item"
open="(" separator="or" close=")">
regexp_like(OTHER_SPECIALITY_CODE,'${item}')
</foreach>
</if>
2)同一字段 like 多值 可区分 单向模糊 和 双向模糊(Oracle和dm未试过,MySQL支持)
双向模糊查询:
SELECT * from `aaaaaaa` where `name` like '%张三