sql - 替换字符串中的符号 - 优化问题
问题描述
有一个字符串:
{([ab1]+[ab2])*([bc1]+[bc2])*([cd2]+[cd3])}
和一个集合(varchar2(3)的pls_integer索引表):
[ab1] := 1000
[cd3] := 1000
[bc1] := 10000
[cd2] := 10000
[bc2] := 20000
[ab2] := 20000
仅供参考:这个集合是通过 填充的SELECT
,所以可以用于下面描述的问题:
我的目标是用这个集合中的数量替换字符串中的符号,并获得:
'(1000+20000)*(10000+20000)*(10000+1000)'
我已经在 PL/SQL 中使用循环完成了这项工作,然后通过正则表达式找到第一次出现的 3 字符符号,替换等。
我的问题:是否可以在一个查询中完成?
样品选择:
SELECT '[ab1]' AS symbol, 1000 AS amt from dual union all
SELECT '[cd3]',1000 from dual union all
SELECT '[bc1]',10000 from dual union all
SELECT '[cd2]',10000 from dual union all
SELECT '[bc2]',20000 from dual union all
SELECT '[ab2]',20000 from dual;
解决方案
使用递归子查询因式分解子句:
查询:
WITH variables ( id, variable, value ) AS (
SELECT 1, '[ab1]', 1000 FROM DUAL UNION ALL
SELECT 2, '[cd3]', 1000 FROM DUAL UNION ALL
SELECT 3, '[bc1]', 10000 FROM DUAL UNION ALL
SELECT 4, '[cd2]', 10000 FROM DUAL UNION ALL
SELECT 5, '[bc2]', 20000 FROM DUAL UNION ALL
SELECT 6, '[ab2]', 20000 FROM DUAL
),
equations ( equation ) AS (
SELECT '{([ab1]+[ab2])*([bc1]+[bc2])*([cd2]+[cd3])}' FROM DUAL UNION ALL
SELECT '{([ab2]+[bc1])}' FROM DUAL
),
substitutions ( equation, id, max_id ) AS (
SELECT REPLACE( equation, variable, value ),
v.id,
v.max_id
FROM equations e
INNER JOIN
( SELECT v.*,
MAX( id ) OVER () AS max_id
FROM variables v
) v
ON ( v.id = 1 )
UNION ALL
SELECT REPLACE( equation, variable, value ),
v.id,
s.max_id
FROM substitutions s
INNER JOIN
variables v
ON ( s.id + 1 = v.id )
)
SELECT equation
FROM substitutions
WHERE id = max_id
输出:
| 方程 | | :---------------------------------------------------- | | {(1000+20000)*(10000+20000)*(10000+1000)} | | {(20000+10000)} |
db<>在这里摆弄
推荐阅读
- c# - Sqlite 在 C# 中将数据库移动到内存
- python - “将温度从 f 转换为 c”在 def 中不起作用
- powershell - Powershell 添加重复的 IIS 应用程序池
- django - Django Match-team-player 关系玩家选择
- android - MVVM 架构上的 ItemTouchHelper
- cmd - 如何在 CMD 中使用 -t -l 65500 ping HTTPS 网站
- python - 无法替换 json 对象中的参数值
- c - C shuffle 2D 数组
- python - Matplotlib 不绘制负值:极具误导性
- sapui5 - 如何有效地重置绑定控制值?