首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >用于验证数据是否包含数字(或空也有效)的正则表达式

用于验证数据是否包含数字(或空也有效)的正则表达式
EN

Stack Overflow用户
提问于 2010-03-31 15:11:52
回答 3查看 26.3K关注 0票数 1

我必须验证数据是否包含数字,如果不是数字,则返回0,如果是数字或空,则返回1。

下面是我在SQL中尝试过的查询。

SELECT dbo.Regex('^[0-9]','123') --返回1。

SELECT dbo.Regex('^[0-9]','') --这不是返回1,但我想返回为1,并且我尝试在"pattern“中放入空格,它也不起作用……

有没有人能帮上忙...

提前感谢

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2010-03-31 15:15:05

尝试:

代码语言:javascript
运行
复制
SELECT dbo.Regex('^[0-9]*$','123')

或者更好:

代码语言:javascript
运行
复制
SELECT dbo.Regex('^\d*$','123')

\d[0-9]的标准简写。请注意,当您使用[0-9]时,它的意思是“只匹配一个数字。*通配符表示匹配零个或多个数字,因此\d*表示匹配零个或多个数字,其中包含一个空结果。

票数 4
EN

Stack Overflow用户

发布于 2010-03-31 15:18:41

您的正则表达式并不完全正确:"^[0-9]"只检查字符串中的第一个字符是否为数字。您的正则表达式将在"3abcde“上返回1

使用

代码语言:javascript
运行
复制
"^\d*$"

检查字段是否只包含数字(或不包含任何数字)。如果要允许使用空格,请使用

代码语言:javascript
运行
复制
"^\s*\d*\s*$"

如果您希望允许使用符号和小数,请尝试

代码语言:javascript
运行
复制
"^\s*(+|-)?\d*\.?\d*\s*$"
票数 3
EN

Stack Overflow用户

发布于 2010-03-31 15:15:13

尝试^[0-9]*$,它将仅匹配0个或更多个数字:

代码语言:javascript
运行
复制
SELECT dbo.Regex('^[0-9]*$','')

应该返回1,就像应该...

代码语言:javascript
运行
复制
SELECT dbo.Regex('^[0-9]*$','123')
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2551053

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档