利用sql 写一个正则表达式 判断 是否为手机号码 11 位 + 数字... 变量@TelNo

 我来答
红楼花雾
推荐于2017-11-24 · TA获得超过848个赞
知道小有建树答主
回答量:424
采纳率:100%
帮助的人:453万
展开全部
在数据表中加需要约束的那一列的一个约束就行了!表达式如下:
CHECK=([列名] like '13[0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9]')
希望我的回答对你有所帮助,谢谢采纳!!
追问
这个只是一个参数~要用sql 判断用户输入是否正确~~
还有就是我想学正则表达式~~~
嘿嘿 灰常感谢
路人生
2011-09-10 · 超过12用户采纳过TA的回答
知道答主
回答量:66
采纳率:0%
帮助的人:24.4万
展开全部
我的想法和下面位朋友差不多,但是可以直接用:
在数据表中加需要约束的那一列的一个约束就行了!表达式如下:
where ([列名] like '13[0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9]')
注释:[0-9]代表是选任一一个0-9中的数字作为当前位的数字。希望能对你有所帮助和启发。
追问
declare @TelNo decimal
set @TelNo=11111111111
if @TelNo like '1[0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9]'
begin
select '成功' msg
return
end
这个倒是可以判断 但是不是正则表达式判断 sql 里面有正则表达式 小弟想学一下~
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友59d1d93f2
2011-09-10 · TA获得超过1.2万个赞
知道小有建树答主
回答量:1063
采纳率:100%
帮助的人:705万
展开全部
@TelNo = \\d{11}\;
更多追问追答
追问
这个是vs里面的吧~~能只用sql   做么?
格式类似于这样的
declare @TelNo decimal(11,0)
if @TelNo\d{11}\--表达式
begin
select '输入有误' msg
return
end
追答
Oracle10i里好像有正则表达式。
你直接写个函数检查它是不是11位的数字不就好了吗?

参考资料: 2

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式