是否有一种方法来检测一个值在MySQL查询中是否是一个数字?如

SELECT * 
FROM myTable 
WHERE isANumber(col1) = true

当前回答

这个答案与Dmitry类似,但它允许小数以及正数和负数。

select * from table where col1 REGEXP '^[[:digit:]]+$'

其他回答

尝试除法/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:]]+$'

这在大多数情况下都是可行的。

SELECT * FROM myTable WHERE concat('',col1 * 1) = col1

不适合非标准的数字,比如

1 e4 1.2 e5 123. (落后于小数)

我建议:如果你的搜索很简单,你可以使用'

column*1 = column

' operator interesting:)是工作,并且比varchar/char字段更快

SELECT * FROM myTable WHERE column = 1;

ABC*1 => 0 (NOT EQU **ABC**)
AB15*A => 15 (NOT EQU **AB15**)
15AB => 15 (NOT EQU **15AB**)
15 => 15 (EQUALS TRUE **15**)

你可以使用CAST

  SELECT * from tbl where col1 = concat(cast(col1 as decimal), "")