gpt4 book ai didi

sql - 在查询sql postgresql中替换A-Z和0-9

转载 作者:行者123 更新时间:2023-11-29 14:14:56 25 4
gpt4 key购买 nike

我目前有字符串,例如 E-1082067D,我想为每一行查询这些字符串的简化版本。返回 L(用于代替 A-Z 的字母)、S(用于符号)和 N(用于数字 0-9)。我无法更新数据库或创建新表,因为我没有权限,只想查询数据。

到目前为止,我已经将我的字符串拆分为单独的字符,现在我想替换拆分的字符并将它们连接在一起以给出我的最终结果,例如 E-1082067D 将是 LSDDDDDDDL

任何有关如何清理以下内容或我是否以错误方式处理此问题的反馈都将不胜感激。

s

elect site_name,natid, x, COUNT (x), substring(natid,1,1)as a,
substring(natid,2,1)as b,
substring(natid,3,1)as c,
substring(natid,4,1)as d,
substring(natid,5,1)as e,
substring(natid,6,1)as f,
substring(natid,7,1)as g,
substring(natid,8,1)as h,
substring(natid,9,1)as i,
substring(natid,10,1)as j,
substring(natid,11,1)as k,
substring(natid,12,1)as l,
substring(natid,13,1)as m
from (
select site_name, subject_id, natid,natidchk, length(natid)as x
from demog
order by x) as y
group by natid, site_name, x
order by site_name, x;

最佳答案

这可以通过使用多个正则表达式来实现:

with data (natid) as (
values
('E-1082067D'),
('X&42FOO567$BAR')
)
select natid,
regexp_replace(regexp_replace(regexp_replace(natid, '([A-Z])', 'L', 'ig'), '[0-9]', 'N', 'ig'), '[-&$]', 'S', 'ig')
from data;

首先所有出现的A-Z被替换为L,然后所有出现的0-9被替换为N-&$ 替换为 S

以上返回:

natid          | regexp_replace
---------------+---------------
E-1082067D | LSNNNNNNNL
X&42FOO567$BAR | LSNNLLLNNNSLLL

关于sql - 在查询sql postgresql中替换A-Z和0-9,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52388591/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com