是否有一种方法来检测一个值在MySQL查询中是否是一个数字?如
SELECT *
FROM myTable
WHERE isANumber(col1) = true
是否有一种方法来检测一个值在MySQL查询中是否是一个数字?如
SELECT *
FROM myTable
WHERE isANumber(col1) = true
当前回答
如果你的数据是" test " " test0 " " test1111 " " 111test " " 111 "
选择所有数据类型为简单整型的记录:
SELECT *
FROM myTable
WHERE col1 REGEXP '^[0-9]+$';
结果:‘111’
(在正则表达式中,^表示开始,$表示结束)
使用实例选择存在整数或十进制数的所有记录。
SELECT *
FROM myTable
WHERE col1 REGEXP '^[0-9]+\\.?[0-9]*$'; - for 123.12
结果:'111'(与上一个示例相同)
最后,要选择number存在的所有记录,使用以下命令:
SELECT *
FROM myTable
WHERE col1 REGEXP '[0-9]+';
结果:'test0'和'test1111'和'111test'和'111'
其他回答
这在大多数情况下都是可行的。
SELECT * FROM myTable WHERE concat('',col1 * 1) = col1
不适合非标准的数字,比如
1 e4 1.2 e5 123. (落后于小数)
这个答案与Dmitry类似,但它允许小数以及正数和负数。
select * from table where col1 REGEXP '^[[:digit:]]+$'
仍然缺少这个简单的版本:
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
我发现这很有效
if(col1/col1= 1,'number',col1) AS myInfo
你也可以使用正则表达式…就像:
SELECT * FROM myTable WHERE col1 REGEXP '^[0-9]+$';
参考: http://dev.mysql.com/doc/refman/5.1/en/regexp.html