首页 / ORACLE / mysql-Oracle替换功能
mysql-Oracle替换功能
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了mysql-Oracle替换功能,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1196字,纯文字阅读大概需要2分钟。
内容图文
![mysql-Oracle替换功能](/upload/InfoBanner/zyjiaocheng/887/fa63bb9522964affb50eebf1a85c528e.jpg)
选择查询时,我需要从Table2的值替换Table1的字段值.
例如:
表格1:
Org Permission
--------------------------------------
Company1 1,3,7
Company2 1,3,8
表2:
Permission Permission
--------------------------------------
1 Read
3 Write
7 Execute
8 Delete
我需要这样:
Org Permission
--------------------------------------
Company1 Read,Write,Execute
Company2 Read,Write,Delete
解决方法:
如果您不想更新现有表,而只想选择数据,则可以使用这种费力的查询.
http://sqlfiddle.com/#!4/22909/4
WITH changed_table AS
(SELECT val1, EXTRACTVALUE (x.COLUMN_VALUE, 'e') val2new
FROM (SELECT val1, val2 xml_str
FROM table1),
TABLE (XMLSEQUENCE (XMLTYPE ( '<e><e>'
|| REPLACE (xml_str, ',', '</e><e>')
|| '</e></e>'
).EXTRACT ('e/e')
)
) x)
SELECT ct.val1, listagg(table2.val2,',') within group (order by table2.val2) val2
FROM changed_table ct, table2 table2
WHERE ct.val2new = table2.val1
group by ct.val1;
我已经使用XMLTYPE将逗号分隔的数字分隔为行.然后将行与第二个表连接起来以获得描述,最后使用LISTAGG函数形成逗号分隔的字符串.不知道此查询的效率如何.我同意马克·班尼斯特的评论.
内容总结
以上是互联网集市为您收集整理的mysql-Oracle替换功能全部内容,希望文章能够帮你解决mysql-Oracle替换功能所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。