在 MySQL 中如何检查一个值是否为整数?

WBOY
发布: 2023-08-25 12:17:03
转载
1961 人浏览过

在 MySQL 中如何检查一个值是否为整数?

要检查给定值是否是字符串,我们使用cast()函数。如果该值不是数字则返回 0,否则返回数字值。这样我们就可以检查该值是否是整数。

情况 1 - 检查带有整数的字符串

mysql> select cast('John123456' AS UNSIGNED);
登录后复制

以下是输出。表明该值不是数字,因此返回0。

+--------------------------------+
| cast('John123456' AS UNSIGNED) |
+--------------------------------+
|                              0 |
+--------------------------------+
1 row in set, 1 warning (0.00 sec)
登录后复制

情况 2 - 仅检查整数值

mysql> select cast('123456' AS UNSIGNED);
登录后复制

以下是输出。它表明该值是数字,因此返回值本身。

+----------------------------+
| cast('123456' AS UNSIGNED) |
+----------------------------+
|                     123456 |
+----------------------------+
1 row in set (0.00 sec)
登录后复制

这个逻辑对于浮动也很有效。

以下是浮点值的查询。

mysql>  SELECT CAST('78.90' AS UNSIGNED);
登录后复制

这是输出。

+---------------------------+
| CAST('78.90' AS UNSIGNED) |
+---------------------------+
|                        78 |
+---------------------------+
1 row in set, 1 warning (0.00 sec)
登录后复制

与常规运算符的替代逻辑

它适用于任何值的所有条件,甚至是浮点数。

让我们创建一个新表。

mysql> create table CheckingIntegerDemo
   -> (
   -> Value varchar(200)
   -> );
Query OK, 0 rows affected (0.88 sec)
登录后复制

将记录插入表中。

mysql> insert into CheckingIntegerDemo values('John123456');
Query OK, 1 row affected (0.10 sec)

mysql>  insert into CheckingIntegerDemo values('123456');
Query OK, 1 row affected (0.16 sec)

mysql> insert into CheckingIntegerDemo values('123.456');
Query OK, 1 row affected (0.16 sec)
登录后复制

显示所有记录。

mysql> select *from CheckingIntegerDemo;
登录后复制

这是输出。

+------------+
| Value      |
+------------+
| John123456 |
| 123456     |
| 123.456    |
+------------+
3 rows in set (0.00 sec
登录后复制

上面的输出中,只有 123456 是整数,其余都不是整数。

检查值是否为整数的语法。

select yourColumnName from yourTableName where yourColumnName REGEXP '^-?[0-9]+$';
登录后复制

我们使用正则表达式的查询。这将仅输出整数值。

mysql> select Value from CheckingIntegerDemo where Value REGEXP '^-?[0-9]+$';
登录后复制

以下是输出。

+--------+
| Value  |
+--------+
| 123456 |
+--------+
1 row in set (0.00 sec)
登录后复制

以上是在 MySQL 中如何检查一个值是否为整数?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:tutorialspoint.com
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!