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