是否有一种方法来检测一个值在MySQL查询中是否是一个数字?如
SELECT *
FROM myTable
WHERE isANumber(col1) = true
是否有一种方法来检测一个值在MySQL查询中是否是一个数字?如
SELECT *
FROM myTable
WHERE isANumber(col1) = true
当前回答
在我的计算机上,另一个似乎比REGEXP更快的替代方法是
SELECT * FROM myTable WHERE col1*0 != col1;
这将选择col1以数值开头的所有行。
其他回答
尝试除法/1
select if(value/1>0 or value=0,'its a number', 'its not a number') from table
这个答案与Dmitry类似,但它允许小数以及正数和负数。
select * from table where col1 REGEXP '^[[:digit:]]+$'
我发现这很有效
if(col1/col1= 1,'number',col1) AS myInfo
在我的计算机上,另一个似乎比REGEXP更快的替代方法是
SELECT * FROM myTable WHERE col1*0 != col1;
这将选择col1以数值开头的所有行。
使用UDF(用户定义函数)。
CREATE FUNCTION isnumber(inputValue VARCHAR(50))
RETURNS INT
BEGIN
IF (inputValue REGEXP ('^[0-9]+$'))
THEN
RETURN 1;
ELSE
RETURN 0;
END IF;
END;
那么当你询问时
select isnumber('383XXXX')
——返回0
select isnumber('38333434')
——返回1
Select isnumber(mycol) mycol1, col2, colx; ——将为列mycol1返回1和0
-你可以增强功能,采取小数,科学记数法,等等…
使用UDF的优点是可以在“where子句”比较的左侧或右侧使用它。这在发送到数据库之前极大地简化了SQL:
SELECT * from tablex where isnumber(columnX) = isnumber('UnkownUserInput');
希望这能有所帮助。