0

0

mysql中类型转换函数(CAST、CONVERT)使用示例

P粉602998670

P粉602998670

发布时间:2026-01-29 06:51:25

|

524人浏览过

|

来源于php中文网

原创

CAST与CONVERT功能基本等价,均用于显式类型转换,但语法不同:CAST(expr AS type)符合SQL92标准,CONVERT(expr, type)为MySQL扩展;CONVERT还支持CONVERT(expr USING charset)字符集转换,CAST不支持。

mysql中类型转换函数(cast、convert)使用示例

CAST 和 CONVERT 在 MySQL 中的等价性与语法差异

MySQL 中 CASTCONVERT 功能基本一致,都用于显式类型转换,但语法结构不同:CAST(expr AS type) 更标准(SQL92),CONVERT(expr, type) 是 MySQL 扩展写法。二者在绝大多数场景下可互换,但 CONVERT 支持额外的字符集转换形式:CONVERT(expr USING charset),这是 CAST 不具备的。

  • CAST('123' AS UNSIGNED)CONVERT('123', UNSIGNED) 效果相同
  • CONVERT('hello' USING utf8mb4) 合法,CAST('hello' AS utf8mb4) 会报错
  • 目标类型名大小写不敏感,INTintInteger 均可
  • 若转换失败(如 CAST('abc' AS SIGNED)),MySQL 默认返回 0 或空字符串,取决于上下文和 SQL 模式

常见类型转换场景与安全写法

实际开发中,多数转换发生在字符串与数字之间、日期格式标准化、以及字段对齐时。直接用 CAST/CONVERT 隐含风险:无校验、静默失败。建议结合 IF 或正则预判。

  • 字符串转整数:优先用 CAST(str_col AS SIGNED),但需确认 str_col 只含数字前缀;否则用 REGEXP '^[0-9]+$' 过滤
  • 时间字符串转日期:CAST('2023-10-05 14:30' AS DATETIME) 成功,但 CAST('2023/10/05' AS DATE) 失败(格式不符),应先用 STR_TO_DATE()
  • 数字转字符串:用 CAST(num_col AS CHAR),比隐式拼接(如 CONCAT('', num_col))更明确,且避免自动截断
  • 二进制数据转十六进制显示:CONVERT(bin_col USING latin1) 不适用,应改用 HEX(bin_col)

NULL、空值与错误处理的实际表现

CAST(NULL AS type) 总是返回 NULL,这点可靠;但非 NULL 输入一旦无法解析,行为取决于 sql_mode。默认宽松模式下返回 0 或空,严格模式(如启用 STRICT_TRANS_TABLES)则报错。

DALL·E 2
DALL·E 2

OpenAI基于GPT-3模型开发的AI绘图生成工具,可以根据自然语言的描述创建逼真的图像和艺术。

下载
SELECT 
  CAST('' AS SIGNED) AS empty_to_int,
  CAST('abc' AS SIGNED) AS invalid_to_int,
  CAST('12.34' AS SIGNED) AS float_trunc;
-- 结果:0, 0, 12(小数部分被截断,不四舍五入)
  • 空字符串 '' 转数值 → 0;转日期 → '0000-00-00'(若允许)
  • CAST('12.99' AS DECIMAL(5,2))12.99;但 CAST('12.99' AS DECIMAL(3,1)) 会截为 13.0(精度溢出自动调整)
  • 想捕获转换失败?MySQL 原生不支持 TRY_CAST,需用存储函数封装或应用层判断

性能与索引影响必须注意

WHERE 子句中对字段使用 CASTCONVERT(如 WHERE CAST(id_str AS SIGNED) = 123)会导致该字段无法走索引——因为转换是在运行时逐行计算的。

  • 正确做法:确保比较字段类型一致,例如把 id_str 字段改为 INT 类型并加索引
  • 临时补救:若必须转换,可建生成列 + 索引:ALTER TABLE t ADD id_num INT AS (CAST(id_str AS SIGNED)) STORED, ADD INDEX(id_num);
  • ORDER BY CAST(col AS CHAR) 会强制 filesort,即使 col 本身有索引
  • 批量转换(如导入清洗)建议在应用层做,而非依赖 SQL 函数,减少数据库 CPU 压力

类型转换看着简单,但字段是否为空、源格式是否稳定、目标类型精度是否足够、有没有索引可用——这四个点漏掉任何一个,上线后都可能变成慢查询或数据偏差。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

727

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

328

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

350

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1263

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

360

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

841

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

581

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

423

2024.04.29

Golang 网络安全与加密实战
Golang 网络安全与加密实战

本专题系统讲解 Golang 在网络安全与加密技术中的应用,包括对称加密与非对称加密(AES、RSA)、哈希与数字签名、JWT身份认证、SSL/TLS 安全通信、常见网络攻击防范(如SQL注入、XSS、CSRF)及其防护措施。通过实战案例,帮助学习者掌握 如何使用 Go 语言保障网络通信的安全性,保护用户数据与隐私。

2

2026.01.29

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 2万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 812人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号