使用oracle校验


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则表示字符串不符合邮箱格式。

 

你可能感兴趣的:(数据库)