是否有一种方法来检测一个值在MySQL查询中是否是一个数字?如
SELECT *
FROM myTable
WHERE isANumber(col1) = true
是否有一种方法来检测一个值在MySQL查询中是否是一个数字?如
SELECT *
FROM myTable
WHERE isANumber(col1) = true
当前回答
你可以使用CAST
SELECT * from tbl where col1 = concat(cast(col1 as decimal), "")
其他回答
您可以使用正则表达式的mor细节https://dev.mysql.com/doc/refman/8.0/en/regexp.html
我用这个^([,|.]?[0-9])+$。这个函数允许对小数和浮点数进行句柄处理
SELECT
*
FROM
mytable
WHERE
myTextField REGEXP "^([,|.]?[0-9])+$"
这个答案与Dmitry类似,但它允许小数以及正数和负数。
select * from table where col1 REGEXP '^[[:digit:]]+$'
在我的计算机上,另一个似乎比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
你可以使用CAST
SELECT * from tbl where col1 = concat(cast(col1 as decimal), "")