是否有一种方法来检测一个值在MySQL查询中是否是一个数字?如
SELECT *
FROM myTable
WHERE isANumber(col1) = true
是否有一种方法来检测一个值在MySQL查询中是否是一个数字?如
SELECT *
FROM myTable
WHERE isANumber(col1) = true
当前回答
仍然缺少这个简单的版本:
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
其他回答
我建议:如果你的搜索很简单,你可以使用'
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**)
这在大多数情况下都是可行的。
SELECT * FROM myTable WHERE concat('',col1 * 1) = col1
不适合非标准的数字,比如
1 e4 1.2 e5 123. (落后于小数)
我发现这很有效
if(col1/col1= 1,'number',col1) AS myInfo
您可以使用正则表达式的mor细节https://dev.mysql.com/doc/refman/8.0/en/regexp.html
我用这个^([,|.]?[0-9])+$。这个函数允许对小数和浮点数进行句柄处理
SELECT
*
FROM
mytable
WHERE
myTextField REGEXP "^([,|.]?[0-9])+$"
你也可以使用正则表达式…就像:
SELECT * FROM myTable WHERE col1 REGEXP '^[0-9]+$';
参考: http://dev.mysql.com/doc/refman/5.1/en/regexp.html