MySql表达式中字符串类型与整型的隐式转换

隐式转换

当运算符与不同类型的操作数一起使用时,会发生类型转换以使操作数兼容。某些转换是隐式发生的。例如,MySQL 会根据需要自动将字符串转换为数字,反之亦然。

sql 复制代码
mysql> SELECT 1+'1';
        -> 2
mysql> SELECT CONCAT(2,' test');
        -> '2 test'

也可以使用CAST()函数显式地将数字转换为字符串。转换是隐式进行的, CONCAT()因为它需要字符串参数。

sql 复制代码
mysql> SELECT 38.8, CAST(38.8 AS CHAR);
        -> 38.8, '38.8'
mysql> SELECT 38.8, CONCAT(38.8);
        -> 38.8, '38.8'

字符串转为整型的规则

隐式转换遵循从左到右解析数字字符的规则,非数字字符后的内容会被丢弃。例如:

  • '123abc'转换为123'abc123'转换为0
sql 复制代码
mysql> SELECT 1 > '6x';
        -> 0
mysql> SELECT 7 > '6x';
        -> 1
mysql> SELECT 0 > 'x6';
        -> 0
mysql> SELECT 0 = 'x6';
        -> 1

引发问题

字段类型是字符串类型,传入类型是整型

1.索引失效导致全表扫描
  • 原因 :MySQL会将VARCHAR字段的值隐式转换为整数(如CAST(column AS SIGNED)),导致索引失效,触发全表扫描 。
  • 影响:查询性能急剧下降,尤其是大表场景下,可能导致数据库CPU和I/O资源飙升
sql 复制代码
SELECT * FROM user WHERE varchar_column = 123; 
-- 实际等价于:SELECT * FROM user WHERE CAST(varchar_column AS SIGNED) = 123
sql 复制代码
SELECT * FROM test WHERE varchar_column = 0; 
-- 可能匹配到字段值为'abc'(转为0)、'0xyz'(转为0)等非预期数据。
2.数据插入/更新的隐式转换风险
  • 原因 :向VARCHAR字段插入INT值时,MySQL会自动转换为字符串,但可能导致:
    • 前导零丢失 :例如插入0000会存储为'0',而非'0000'
    • 数值超长截断 :若INT值超过字段定义长度(如VARCHAR(3)插入1234),会触发截断或报错(取决于严格模式)
相关推荐
UCoding2 分钟前
我们来学mysql -- “数据备份&还原”sh脚本
mysql
运维老曾7 分钟前
MySQL半同步复制配置和参数详解
数据库·mysql
mine_wz7 分钟前
ClamAV使用
数据库·oracle
好奇的菜鸟9 分钟前
在 WSL Ubuntu-24.04 上安装 Nacos 2.5.1 并使用 MySQL 数据库
数据库·mysql·ubuntu
heart000_115 分钟前
MySQL索引与性能优化入门:让查询提速的秘密武器【MySQL系列】
数据库·mysql·性能优化
23级二本计科36 分钟前
二.MySQL库的操作
数据库·mysql
度假的小鱼1 小时前
【KWDB 创作者计划】_探秘浪潮KWDB数据库:从时间索引到前沿技术
数据库·kwdb
喝养乐多长不高1 小时前
深入探讨redis:主从复制
数据库·redis·缓存·主从模式·主从复制·全量复制·部分复制
heart000_12 小时前
MySQL项目实战演练:搭建用户管理系统的完整数据库结构【MySQL系列】
数据库·mysql·oracle
telllong3 小时前
几种常用的Agent的Prompt格式
大数据·数据库·prompt