使用oracle校验

本文介绍如何使用SQL查询来验证数据的完整性,包括检查字段是否非空、是否包含空格、是否为合法的中文姓名、身份证及邮箱格式。通过具体SQL语句示例,帮助读者掌握数据校验的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


1、非空

select * FROM T_NAME where colum is not null;


2、是否包含空格

select * FROM T_NAME  WHERE instr(COLNAME,' ')>0;--空格存在的位置大于0,即存在空格;

SELECT * FROM T_NAME WHERE REGEXP_LIKE(COLNAME, '( )+');--只要有空格就可以检测出来;字符中含有空格的;

3、是否是中文姓名(不含非法字符,字母,数字)

select * from  t_name where regexp_like(colum , '[^'|| unistr('\4e00')|| '-'|| unistr('\9fa5')||']');


4、身份证是否合法
使用存储过程

5、邮箱是否合法

在数据库中,有时需要判断字符串是否是一个或者多个邮箱格式,可以使用如下语句判断:

SELECT COUNT(1)  
FROM dual  
WHERE regexp_like(v_mail,'^\w+((-\w+)|(\.\w+))*\@[A-Za-z0-9]+((\.|-)[A-Za-z0-9]+)*\.[A-Za-z0-9]+(;{1,1}\w+((-\w+)|(\.\w+))*\@[A-Za-z0-9]+((\.|-)[A-Za-z0-9]+)*\.[A-Za-z0-9]+)*$')


代码中v_mail即为邮箱字符串,如果多个邮箱,以分号隔开。语句返回1则表示字符串符合邮箱格式,返回0则表示字符串不符合邮箱格式。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值