动态选择和替换(清理)数据 - 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的主要内容,如果未能解决你的问题,请参考以下文章

如何在列表和标签中插入动态 SQL?

sql server数据库日志怎么清理

oracle sql中的动态数据透视

如何清理sql server 2008日志

SQL如何替换选择返回的值?

如何清理服务器里面的日志?