在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)
语法二(字符集转换):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) DATETIME 或 TIMESTAMP:日期时间 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 或条件判断使用。
