文章目录

  • Oracle中的列转行实现字段拼接

场景

在SQL使用过程中经常有这种需求:将某列字段拼接成in('XX','XX','XX','XX','XX','XX' ...)做为查询条件。

实现

select 'in ('''||replace(wm_concat(EMPNO),',',''',''')||''')' from EMP

总结

  1. 两端字符的拼接
  1. 这里用'in ('''''')'分别实现了in ('')的前后拼接,以''')'为例,其中第一个第四个'是Oracle中的字符串连接符,第二个'是一个转义字符,第三个'才是我们真正被转义的内容。
  2. lpad()、rpad()在两端字符的填充中较难控制填充字符串长度。
  1. wm_concat的使用

这里推荐使用LISTAGG()函数,主要因为:

  1. 在不同的oracle版本中,WMSYS.WM_CONTACT返回的数据类型不一致,10G版本中,返回的是字符串类型,11G版本中,返回的是clob类型,Oracle 11gR2和12C上已经摒弃了wm_concat函数。
  2. LISTAGG()支持自定义分割字符串,默认值为 NULL,而WMSYS.WM_CONTACT固定只能用'拼接,除非使用REPLACE()替换为不同拼接符。
select  mgr,'in (''' ||REPLACE(LISTAGG(EMPNO, ',') within group(order by mgr), ',', ''','& 大专栏  Oracle中的列转行实现字段拼接用例#39;') || ''')' from EMP group by mgr

扩展

转义符

  • '(单引号)的转义
Select 'test' || '''' from dual;
Select 'test ''' from dual;
  • ASCII码实现转义
Select 'Tom' || chr(38) || 'Jerry' from dual;  --chr(38)是‘&'的ASCII码
  • ESCAPE转义

使用 ESCAPE关键字定义转义符。 在模式中,当转义符置于通配符之前时,该通配符就解释为普通字符。

SELECT * FROM t_test tt WHERE tt.t_ch LIKE '%%'; -- 查找全部
SELECT * FROM t_test tt WHERE tt.t_ch LIKE '%_%'; -- 查找全部
SELECT * FROM t_test tt WHERE tt.t_ch LIKE '%/%'; -- 查找含有左斜杠
SELECT * FROM t_test tt WHERE tt.t_ch LIKE '%/%%' ESCAPE '/'; -- 使用/转义,查找含有%的字符
SELECT * FROM t_test tt WHERE tt.t_ch LIKE '%/_%' ESCAPE '/'; -- 使用/转义,查找含有_的字符

LISTAGG函数

  • 语法
  LISTAGG(aggregate_expression [, 'delimiter' ] )  [ WITHIN GROUP (ORDER BY order_list) ]
  • 参数
  1. aggregate_expression:
    提供要聚合的值的任何有效表达式(如列名称)。忽略 NULL 值和空字符串。LISTAGG 不支持 DISTINCT 表达式。
  2. delimiter:
    可选。将分隔串联的值的字符串常数。默认值为 NULL。
  3. WITHIN GROUP (ORDER BY order_list):
    可选。指定聚合值的排序顺序。
  • 返回值

VARCHAR(MAX)。如果结果集大于最大 VARCHAR 大小(64K – 1 或 65535),则 LISTAGG 返回以下错误:

  Invalid operation: Result size exceeds LISTAGG limit

最新文章

  1. Find and delete duplicate files
  2. JVM参数OmitStackTraceInFastThrow:不打印NullPointerException异常堆栈
  3. Oracle 11g 新特性之Highly Available IP(HAIP)
  4. 使用django rest framework
  5. Zabbix安装图解教程
  6. Laxcus大数据管理系统单机集群版
  7. 我的MySQL5.6免安装版配置过程
  8. ion torrent ion proton
  9. WinForm中如何判断关闭事件来源于用户点击右上角的“关闭”按钮
  10. 自定义UICollectionViewController之后 如何设置UICollectionView的布局方式--备用
  11. insert当 sql语句里面有变量 为字符类型的时候 要3个单引号
  12. CDH5 安装过程
  13. JavaScript引用类型之Array数组的toString()和valueof()方法的区别
  14. JQuery的JSTree使用
  15. 函数alv下的颜色设置
  16. SpringMVC+Spring+hibernate整合及分页
  17. webapi “ObjectContent`1”类型未能序列化内容类型“application/xml; charset=utf-8”的响应正文。
  18. thinkphp碰到的一些小问题
  19. 织梦5.7sp1最新问题:后台不显示编辑器
  20. Servlet_note

热门文章

  1. android新闻项目、饮食助手、下拉刷新、自定义View进度条、ReactNative阅读器等源码
  2. C#匿名委托,匿名函数,lambda表达式
  3. UML-词汇表
  4. tc/traffic control 网络控制工具
  5. BaseAdapter教程(2) BaseAdapter的notifyDataSetChanged动态刷新
  6. Vscode 下 PlantUML 插件的安装(windows and ubuntu)
  7. mysql之结果集去重
  8. 一、安装Docker CE
  9. ddt-python测试数据驱动工具(转载)
  10. djangp-filter的使用