mysql字符串转为数字的三种方法、字符串转日期

隐式转换

在MySQL中,使用+0运算符可以将一个非数字的值隐式地转换为数字。这在进行数学运算或比较操作时非常有用。
需要注意的是,在使用+0进行隐式转换时,MySQL会尽可能将字符串转换为数字。如果字符串不能转换为数字,则会返回0。

mysql> select "000123456";
+-----------+
| 000123456 |
+-----------+
| 000123456 |
+-----------+
1 row in set (0.00 sec)
mysql> select "000123456"+0;
+---------------+
| "000123456"+0 |
+---------------+
|        123456 |
+---------------+
1 row in set (0.00 sec)

显式转换

CAST

在MySQL中,CAST函数用于将一个表达式转换为指定的数据类型。它可以用于将一个值转换为不同的数据类型,例如整数、浮点数、字符串等。CAST函数的语法如下:

CAST(expression AS data_type)

其中,expression是要进行转换的表达式,data_type是要转换成的目标数据类型。
使用CAST函数时,需要注意以下几点:

如果转换失败,MySQL会返回一个NULL值。例如,将一个非数字字符串转换为整数时会失败。
CAST函数在执行时可能会导致精度损失或溢出,特别是将一个大的值转换为小的数据类型时。
在某些情况下,可以直接使用类型转换操作符(如+0)来进行类型转换,这通常比使用CAST函数更高效。

mysql> select CAST("000123456" AS SIGNED);
+-----------------------------+
| CAST("000123456" AS SIGNED) |
+-----------------------------+
|                      123456 |
+-----------------------------+
1 row in set (0.01 sec)

mysql> select CAST("000123456" AS UNSIGNED);
+-------------------------------+
| CAST("000123456" AS UNSIGNED) |
+-------------------------------+
|                        123456 |
+-------------------------------+
1 row in set (0.00 sec)

mysql> select CAST("-000123456" AS SIGNED);
+------------------------------+
| CAST("-000123456" AS SIGNED) |
+------------------------------+
|                      -123456 |
+------------------------------+
1 row in set (0.00 sec)

mysql> select CAST("-000123456" AS DECIMAL);
+-------------------------------+
| CAST("-000123456" AS DECIMAL) |
+-------------------------------+
|                       -123456 |
+-------------------------------+
1 row in set (0.02 sec)

mysql> select CAST("000123456" AS DECIMAL);
+------------------------------+
| CAST("000123456" AS DECIMAL) |
+------------------------------+
|                       123456 |
+------------------------------+
1 row in set (0.00 sec)

CONVERT

在MySQL中,可以使用CONVERT()函数来转换数据类型或格式。该函数用于将一个表达式转换为指定的数据类型或格式。
CONVERT()函数的语法如下:

CONVERT(expression, data_type)

其中,expression是要进行转换的表达式,data_type是要转换成的目标数据类型。
需要注意的是,CONVERT()函数可以用于日期和时间类型的转换,并且可以指定日期格式。

mysql> select CONVERT("000123456", SIGNED);
+------------------------------+
| CONVERT("000123456", SIGNED) |
+------------------------------+
|                       123456 |
+------------------------------+
1 row in set (0.02 sec)

mysql> select CONVERT("000123456", UNSIGNED);
+--------------------------------+
| CONVERT("000123456", UNSIGNED) |
+--------------------------------+
|                         123456 |
+--------------------------------+
1 row in set (0.00 sec)

mysql> select CONVERT("000123456", DECIMAL);
+-------------------------------+
| CONVERT("000123456", DECIMAL) |
+-------------------------------+
|                        123456 |
+-------------------------------+
1 row in set (0.00 sec)

mysql> select CONVERT("-000123456", SIGNED);
+-------------------------------+
| CONVERT("-000123456", SIGNED) |
+-------------------------------+
|                       -123456 |
+-------------------------------+
1 row in set (0.00 sec)

mysql> select CONVERT("-000123456", DECIMAL);
+--------------------------------+
| CONVERT("-000123456", DECIMAL) |
+--------------------------------+
|                        -123456 |
+--------------------------------+
1 row in set (0.00 sec)

字符串转日期

下面是一个使用CONVERT函数将日期从一种格式转换为另一种格式的示例:

mysql> SELECT CONVERT('2023-11-23', DATE) AS converted_date;
+----------------+
| converted_date |
+----------------+
| 2023-11-23     |
+----------------+
1 row in set (0.00 sec)

在上面的示例中,日期’2019-12-31’被转换为DATE格式,并存储在名为converted_date的列中。

你还可以在转换时使用其他日期格式。下面是一些常见的日期格式:

DATE: 日期格式 (YYYY-MM-DD)
TIME: 时间格式 (HH:MM:SS)
DATETIME: 日期时间格式 (YYYY-MM-DD HH:MM:SS)
YEAR: 年份格式 (YYYY)
如果你想将日期转换为特定的格式,只需在CONVERT函数的第二个参数中指定所需的格式。

参考

https://dev.mysql.com/doc/refman/5.7/en/cast-functions.html#function_convert
https://dev.mysql.com/doc/refman/5.7/en/cast-functions.html#function_cast

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小龙在山东

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值