动态选择和替换(清理)数据 - SQL
Posted
技术标签:
【中文标题】动态选择和替换(清理)数据 - SQL【英文标题】:SELECT and REPLACE (clean) data on the fly - SQL 【发布时间】:2017-12-13 10:24:56 【问题描述】:我是 SQL 新手。我正在尝试从数据库(Postgres)中获取数据,如果这些数据无效,则动态替换它们。使用纯 SQL 可以做到这一点吗?例如,在我的数据库users
中,我的字段phone
包含以下数据:
|phone |
------------------
|+79844533324 |
|893233314215 |
|dfgdhf |
|45 |
|+ |
| |
|(345)53326784457|
|8(123)346-34-45 |
etc..
如果满足以下条件,我只想得到最后十位数字:
-
电话号码以 8 或 7 或 +7 或 +8 开头。
数字在 8 或 7 或 +7 或 +8 之后包含十位数字,不多不少
像这样:
|phone |
------------------
|9844533324 |
|1233463445 |
我想这对 SQL 来说可能很复杂。我研究了大量的手册,但其中大多数只涵盖了带有正则表达式条件的 SELECT。
【问题讨论】:
使用该表数据,同时指定预期结果。 正则表达式应该是要走的路。如果这不起作用,请在 PL/pgSQL 或 PL/Perl 中编写一个函数,以您需要的方式处理数据。 【参考方案1】:我认为这可能有效:
select
right (regexp_replace (phone, '\D', '', 'g'), 10)
from foo
where
phone ~ '^\+?[78]' and
regexp_replace (phone, '\D', '', 'g') ~ '^[78]\d10$'
解释方式:
right (regexp_replace (phone, '\D', '', 'g'), 10)
从字段中删除所有非数字,然后取正确的十个字符——只有满足以下条件才会这样做:
phone ~ '^\+?[78]' and
电话号码以可选的“+”开头,然后是 7 或 8
regexp_replace (phone, '\D', '', 'g') ~ '^[78]\d10$'
去掉所有非数字的字段以 7 或 8 开头,后跟正好十个其他数字。
结果:
9844533324
1233463445
【讨论】:
以上是关于动态选择和替换(清理)数据 - SQL的主要内容,如果未能解决你的问题,请参考以下文章