谈谈MySQL显式类型转换

本文详细探讨了MySQL中的显式类型转换,重点介绍了CAST函数的使用,包括它支持的数据类型,如DATE、TIME、DATETIME等,并给出了各种类型的转换案例。通过了解这些,可以更好地避免类型转换错误并优化SQL查询。
摘要由CSDN通过智能技术生成
本文首发于个人微信公众号《andyqian》,期待您的关注!
前言

  我们之前谈了《谈谈MySQL隐式类型转换》,今天我们来说说MySQL显示类型转换。其实我们之前有简单说过一次,这次主要是掰开揉细了说。

CAST 函数

  在之前的文章中,我们提到过CAST函数,用于显示进行类型转换。在避免隐式类型转换时,好处多多。其实这里面还有很多细节,是需要梳理下的。
首先来看看下面这个转换:

mysql> SELECT CAST('2017-12-14' AS DATE);
+----------------------------+
| CAST('2017-12-14' AS DATE) |
+----------------------------+
| 2017-12-14                 |
+----------------------------+
1 row in set (0.00 sec)

其中:
2017-12-14 是待转换的数据。
DATE为转换后的类型。

标准语法是这样的:

CAST(expr AS type)

这里需要注意的是type类型不支持所有的数据类型,而是支持特定的数据类型,也是今天这篇文章的重点。(我就吃过这个亏,想当然的以为支持所有数据类型,结果就被打脸了) 。

不支持的报错:

mysql> SELECT CAST('1024' AS int);
ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version 
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值