微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

如何解决在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}$')仅在不过滤结果的情况下为您提供所需的字符串部分。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?