Oracle之如何将表数据生成一个分隔列表

171 阅读2分钟

「这是我参与2022首次更文挑战的第12天,活动详情查看:2022首次更文挑战

今日份知识学习

今天我们来学习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数据库的一些知识,其中包含一些函数的使用,或者是特性的介绍讲解等,将会在系列文章内说到。

喜欢的可以关注一下专栏。