在Oracle SQL中,手机号码应从3开始,并且校验长度应为10

问题描述

我在Oracle表列中有手机号码,其数据类型为字符串

  3451111111
923452222222
 03451111211

我希望sql语句仅选择此格式3451111113的移动电话并检查长度= 10。

我想要一个从字符3开始并在长度为10的字符串结尾处结束的子字符串。应该忽略开头的0、92,并开始从3开始计数字符串。

解决方法

您可以使用regexp_like()

where regexp_like(number,'^(0|92)?3[0-9]{9}$')

这将匹配092或字符串开头的任何内容,然后匹配3,再匹配9位数字。

,

您可以使用LIKE

SELECT *
FROM   table_name
WHERE  value LIKE '%3_________';

或者,如果您特别希望以303923开头的字符串,则:

SELECT *
FROM   table_name
WHERE  value LIKE '3_________'
OR     value LIKE '03_________'
OR     value LIKE '923_________';

其中的示例数据:

CREATE TABLE table_name ( value ) AS
SELECT '3451111111' FROM DUAL UNION ALL
SELECT '923452222222' FROM DUAL UNION ALL
SELECT '03451111211' FROM DUAL UNION ALL
SELECT '3' FROM DUAL UNION ALL
SELECT '312345678' FROM DUAL UNION ALL
SELECT '3123456789' FROM DUAL UNION ALL
SELECT '31234567890' FROM DUAL;

两个输出:

| VALUE        |
| :----------- |
| 3451111111   |
| 923452222222 |
| 03451111211  |
| 3123456789   |

db 提琴here

,

要获取最后10位数字:

SUBSTR(phone_num,-10)
,

仅选择最后10个字符均为以3开头的所有数字的值。

select substr(str,-10)
from   demo
where  regexp_like(str,'3\d{9}$');

例如,过滤器将排除30 bananas(后10个字符以3开头,但不是全数字)。它忽略任何前面的字符,因此例如banana3123456789将被报告为3123456789。尚不清楚您是否也要排除它。

regexp_substr(str,'3\d{9}$')仅在不过滤结果的情况下为您提供所需的字符串部分。

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...