如何在mysql中使用CAST和CONVERT转换数据类型

P粉602998670
发布: 2025-10-24 11:52:01
原创
704人浏览过
CAST()和CONVERT()用于MySQL类型转换,语法不同但功能相似。1. CAST(expression AS type)可读性强,如CAST('123' AS SIGNED)将字符串转整数。2. CONVERT(expression, type)支持类型与字符集转换,如CONVERT('99.5', DECIMAL(5,2))。常用类型包括CHAR、SIGNED、DATE等。适用于字段比较、数值计算、格式化输出等场景,需注意无效转换可能返回NULL,建议结合IFNULL使用。

如何在mysql中使用cast和convert转换数据类型

在MySQL中,CAST()CONVERT() 函数用于将一个数据类型转换为另一个数据类型。这两个函数功能相似,语法略有不同,但在大多数场景下可以互换使用。掌握它们有助于处理查询中的类型不匹配问题,比如字符串转数字、日期格式化、数值计算等。

1. 使用 CAST() 进行类型转换

CAST() 的语法结构清晰,可读性强,适合希望代码易于理解的场景。

语法:

CAST(expression AS type)

常见用法示例:

  • 字符串转整数
    SELECT CAST('123' AS SIGNED); -- 结果:123(整型)
  • 数值转字符串
    SELECT CAST(456 AS CHAR); -- 结果:'456'(字符型)
  • 字符串转日期
    SELECT CAST('2025-04-05' AS DATE); -- 结果:2025-04-05(DATE 类型)
  • 浮点数转整数(截断)
    SELECT CAST(12.99 AS SIGNED); -- 结果:12

2. 使用 CONVERT() 进行类型转换

CONVERT() 支持两种语法形式,除了类型转换外,还可用于字符集转换。

语法一(类型转换):

CONVERT(expression, type)

如知AI笔记
如知AI笔记

如知笔记——支持markdown的在线笔记,支持ai智能写作、AI搜索,支持DeepseekR1满血大模型

如知AI笔记27
查看详情 如知AI笔记
语法二(字符集转换):

CONVERT(expression USING charset_name)

类型转换示例:

  • 字符串转十进制数
    SELECT CONVERT('99.5', DECIMAL(5,2)); -- 结果:99.50
  • 整数转字符
    SELECT CONVERT(100, CHAR); -- 结果:'100'
  • 时间字符串转 DATETIME
    SELECT CONVERT('2025-04-05 14:30:00', DATETIME);
  • 使用字符集转换
    SELECT CONVERT('文本' USING utf8mb4);

3. 常见目标数据类型说明

在使用 CAST 或 CONVERT 时,type 参数支持多种类型:

  • CHAR:转换为字符串
  • SIGNED:转换为带符号整数
  • UNSIGNED:转换为无符号整数
  • DECIMAL(M,D):转换为指定精度的小数
  • DATE:仅日期(YYYY-MM-DD)
  • DATETIMETIMESTAMP:日期时间
  • TIME:时间类型
  • BINARY:转换为二进制字符串

4. 实际应用场景

类型转换常用于以下情况:

  • 比较不同类型的字段
    WHERE CAST(user_id AS CHAR) = 'ABC123'
  • 聚合计算时确保数值类型
    SELECT SUM(CAST(price_str AS DECIMAL(10,2))) FROM products;
  • 格式化输出
    SELECT CONCAT('金额:', CONVERT(amount, CHAR)) FROM orders;
  • 处理导入的文本数据:将 CSV 导入后,把 VARCHAR 字段转为 INT 或 DATE。

基本上就这些。CAST 和 CONVERT 能有效解决MySQL中的类型不一致问题,选择哪个主要看个人或团队的编码风格偏好。注意转换无效数据可能导致 NULL 或错误,建议配合 IFNULL 或条件判断使用。

以上就是如何在mysql中使用CAST和CONVERT转换数据类型的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

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