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

SELECT * 
FROM myTable 
WHERE isANumber(col1) = true

当前回答

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

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

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

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

其他回答

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

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

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

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

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

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

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

你可以使用CAST

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

使用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');

希望这能有所帮助。

尝试除法/1

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