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

SELECT * 
FROM myTable 
WHERE isANumber(col1) = true

当前回答

尝试除法/1

select if(value/1>0 or value=0,'its a number', 'its not a number') from table

其他回答

仍然缺少这个简单的版本:

SELECT * FROM myTable WHERE `col1` + 0 = `col1`

(加法应该比乘法快)

或者更慢的版本:

SELECT *, 
CASE WHEN `col1` + 0 = `col1` THEN 1 ELSE 0 END AS `IS_NUMERIC` 
FROM `myTable`
HAVING `IS_NUMERIC` = 1

返回数字行

我发现解决方案与以下查询和工作为我:

SELECT * FROM myTable WHERE col1 > 0;

这个查询返回的行只包含大于0的数字列col1

返回非数字行

如果你想检查列不是数字,试试这个技巧(!Col1 > 0):

SELECT * FROM myTable WHERE !col1 > 0;

你可以使用CAST

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

尝试除法/1

select if(value/1>0 or value=0,'its a number', 'its not a number') from table

你也可以使用正则表达式…就像:

SELECT * FROM myTable WHERE col1 REGEXP '^[0-9]+$';

参考: http://dev.mysql.com/doc/refman/5.1/en/regexp.html