今日份知识学习
今天我们来学习Oracle如何根据表数据,生成一个分隔列表,或者是一个有固定字符分隔的字符串,一起来学习一下吧。
具体讲解
本次要实现的结果是将user_table中的name字段进行一个拼接,生成张三、李四、王五的形式。
wm_concat函数
今天的重点不是说这个函数,wm_concat函数虽然经常被大家使用,但是由于此函数在不同版本中的返回值类型的不同,在一些开发场景下,会造成一些无法预估的问题。
所以这里只是提一下,大家有兴趣的可以自行去查看。
listagg
从oracle 11.2版本开始,增加了listagg函数,通过listagg函数我们可以将字符串进行一个合并,并且指定分隔字符。
让我们来看看具体的示例SQL:
select listagg(name, ',') within group(order by name) from user_table
通过以上SQL可以得到我们想要的分隔字符串了,
这里要说一下group(order by name)是什么意思,group中的order by,意思是拼接的字符串要根据那个字段进行排序,这里我们写的name字段,我们可以换成age字段进行排序,这个需要确认当前的使用场景的需求。
同时,listagg函数还可以搭配聚合函数进行一起使用,比如sum、count等等的聚合函数,皆可以同时和listagg进行查询。
比如下面这个SQL:
select sum(age), listagg(name, ',') within group(order by name) from user_table
总结
今天学习了如何将表数据拼接成一个分隔列表,还可以指定相应的分隔字符,大家是否有更好的办法去实现呢?
最近开始来学习Oracle数据库的一些知识,其中包含一些函数的使用,或者是特性的介绍讲解等,将会在系列文章内说到。
喜欢的可以关注一下专栏。