1、问题的由来
书写MySQL存储过程,有时需要判断传递的某参数是数字还是字母和数字或字母组成的字符串,由于MySQL没有现成的函数,在MSSQL中可以用ISNUMERIC来判断,因此在MYSQL中需要自己写函数来判断了。
2、解决办法
DELIMITER $$
DROP FUNCTION IF EXISTS `funIsNum` $$
CREATE FUNCTION `funIsNum` (Minfo VARCHAR(25)) RETURNS INT
BEGIN
DECLARE iResult INT DEFAULT 0;
SELECT Minfo REGEXP '^[0-9]*$' INTO iResult;
IF iResult = 1 THEN
RETURN 1;
ELSE
RETURN 0;
END IF;
END $$
DELIMITER ;
如果返回1,则说明是纯数字组成的,如果返回0,则说明是字母等组成的字符串 。
3、参考JS正则表达式
Submitted by ricky on 2007, July 25, 3:25 PM. PHP&MySQL
只能输入数字:"^[0-9]*$"。
只能输入n位的数字:"^/d{n}$"。
只能输入至少n位的数字:"^/d{n,}$"。
只能输入m~n位的数字:。"^/d{m,n}$"
只能输入零和非零开头的数字:"^(0|[1-9][0-9]*)$"。
只能输入有两位小数的正实数:"^[0-9]+(.[0-9]{2})?$"。
只能输入有1~3位小数的正实数:"^[0-9]+(.[0-9]{1,3})?$"。
只能输入非零的正整数:"^/+?[1-9][0-9]*$"。
只能输入非零的负整数:"^/-[1-9][]0-9"*$。
只能输入长度为3的字符:"^.{3}$"。
只能输入由26个英文字母组成的字符串:"^[A-Za-z]+$"。
只能输入由26个大写英文字母组成的字符串:"^[A-Z]+$"。
只能输入由26个小写英文字母组成的字符串:"^[a-z]+$"。
只能输入由数字和26个英文字母组成的字符串:"^[A-Za-z0-9]+$"。
只能输入由数字、26个英文字母或者下划线组成的字符串:"^/w+$"。
验证用户密码:"^[a-zA-Z]/w{5,17}$"正确格式为:以字母开头,长度在6~18之间,只能包含字符、数字和下划线。
验证是否含有^%&',;=?$/"等字符:"[^%&',;=?$/x22]+"。
只能输入汉字:"^[/u4e00-/u9fa5]{0,}$"
验证Email地址:"^/w+([-+.]/w+)*@/w+([-.]/w+)*/./w+([-.]/w+)*$"。
^[+-]?/d+$ 整数
^[0-9]*[1-9][0-9]*$ 正整数 (没有+号)
^-[0-9]*[1-9][0-9]*$ 负整数
^/d+$ 正整数 + 0(非负整数)
^((-/d+)|(0+))$ 负整数 + 0(非正整数)
^[a-zA-Z]+$ 由26个英文字母组成的字符串
^[a-zA-Z0-9]+$ 由数字和26个英文字母组成的字符串
^/w+$ 由数字、26个英文字母或者下划线组成的字符串
(^/s+)|(/s+$) 首尾空格
[/u4e00-/u9fa5] 匹配中文字符(Unicode编码),包括简体、繁体中文
^([0-9]){8}([a-zA-Z]){2}$ 前8位数字,后2位字母
^[/w.]+@[/w]+(/.[/w]{2,3}){1,2}$ email地址
(/w+):([/w.]+)//(/S*) URL
验证InternetURL:"^http://([/w-]+/.)+[/w-]+(/[/w-./?%&=]*)?$"。
验证电话号码:"^(/(/d{3,4}-)|/d{3.4}-)?/d{7,8}$"正确格式为:"XXX-XXXXXXX"、"XXXX-XXXXXXXX"、"XXX-XXXXXXX"、"XXX-XXXXXXXX"、"XXXXXXX"和"XXXXXXXX"。
验证身份证号(15位或18位数字):"^/d{15}|/d{18}$"。
验证一年的12个月:"^(0?[1-9]|1[0-2])$"正确格式为:"01"~"09"和"1"~"12"。
验证一个月的31天:"^((0?[1-9])|((1|2)[0-9])|30|31)$"正确格式为;"01"~"09"和"1"~"31"。