Oracle逗号分隔列转行实现方法 |
本文标签:Oracle,列转行 那么,现在如果给出一个权限编号,要去检索出用后这个权限的用户集合,就会需要在逗号分隔的多个权限编号中去匹配给出的这个权限编号 。如果使用like去做,一则效率不高,二则匹配不精确 。因此用到了逗号分隔列转行的方法 。目前该方法只适合在oracle数据库中使用 。该方法只需要sql语句就可以实现列转行 。 下面给出该方法的示例: select a,b,c from 执行以上代码,结果如下图: 模拟数据列 c 中的内容“1,2,3”被转成了三行,前面两列的内容同时附带过去 。在实际运用时,只要把 select aaa a,bbb b,1,2,3 c from dual 替换成实际需要转换的数据表中的字段即可,其中c字段必须是要进行转换的保存逗号分隔内容的字段 。下面的内容都可以不需要更改 。其中“LEVEL <= 100”中的数字100代表匹配字段内容中出现逗号的次数,可以自行更改 。 |