mysql如何实现隐式转换
admin
2023-05-12 03:01:07
0

本文主要给大家简单讲讲mysql如何实现隐式转换,相关专业术语大家可以上网查查或者找一些相关书籍补充一下,这里就不涉猎了,我们就直奔主题吧,希望mysql如何实现隐式转换这篇文章可以给大家带来一些实际帮助。

mysql如何实现隐式转换
我们看上图,yhtest 表,第三列为c、varchar 类型,表中4行数据,当我们使用select * from yhtest where c=0; 进行查询的时候,有三个warning!
mysql如何实现隐式转换
今天我们就从这三个warning 说起,后面的大部分内容可以解释为啥会有这三个warnings!
转换原则:当我们在使用where条件查询的时候,字段类型和赋值类型不一致时,都将转换成整型! 这样一个描述其实是比较模糊的,下面我们具体来看。上图中字段类型为varchar 字符串类型,但是查询条件为c=0 ×××,需要将字段内容都转换为整型,转换方式为:
1)纯字符串内容,则直接转换为0  ‘abc’ 将直接被转换为0
2)含有以数字开头的字符串 ,则会进行截取处理,截取至不是数字的字符串为止,比如‘4abc’ 将 转换为4    ,‘04abc’ 被转换为‘04’ 但是这个在匹配c=4的时候,是会被匹配到的
mysql如何实现隐式转换
3)如果是纯数字字符串,那么将直接转换为对应的×××,比如‘4’ 将直接转换为4
4)以字符开头,数字结尾的,还是将转换为0
这样我们再看开头所报出的warnings ,顿时觉得合理了

很多sql优化的文章中强调:字符串一定记得在where条件中加引号,原因也正是在这里,下面我们看例子
mysql如何实现隐式转换
执行 select  from  yhtest  where c=4 的结果和执行计划如下:
mysql如何实现隐式转换
执行select  from  yhtest  where c='4' 结果和执行计划如下:
mysql如何实现隐式转换
通过执行计划我们看到,第一种where条件后面字段类型 和赋值类型不一致,隐式转换,也没有用到c列上的索引。第二种不存在隐式转换,使用了c列的索引,二者的查询结果也不一样!
上述隐式转换,大部分时候,我们需要用来避免隐式转换带来的不走索引,全表扫描,带来的sql性能问题,但是在数据少的时候,我们可以用来做一些特别操作,比如让'abcdefg'=0?

mysql如何实现隐式转换就先给大家讲到这里,对于其它相关问题大家想要了解的可以持续关注我们的行业资讯。我们的板块内容每天都会捕捉一些行业新闻及专业知识分享给大家的。

相关内容

热门资讯

打造AI影像协作实验场 上影节... 上海国际电影节全新单元“AI片场”开机 打造AI影像协作实验场 “我做AI电影已经两年了。”德国AI...
我国首次成功批量克隆超高产奶山... 西北农林科技大学14日向新华社记者独家披露,学校羊遗传改良与生物育种创新团队攻克关键核心技术,6只超...
医学院硕博研究生靠虚开发票冒签... 33岁的柴某系江苏人,案发前系某医院博士后研究人员。一审法院认定,2018年至2023年,柴某在某医...
京东618自营电脑桌椅服务升级... 随着京东心动购物季开启,职场人、居家办公族及电竞爱好者的“久坐刚需”升级需求集中释放,电脑桌椅品类迎...
扎波罗热核电站遭乌军袭击,两名... 当地时间5月14日,扎波罗热核电站官方通报称,乌克兰武装部队的无人机对核电站周边区域发动袭击。在距离...
储殷:“建设性稳定关系”涵盖了... 特朗普率高规格代表团访华,中方也是高规格接待。中美今天的互动总体呈现出什么特点?这次元首外交又将如何...
中科信息称目前没有研发具身机器... 瑞财经 严明会 5月13日,中科信息在路演活动中表示,公司目前没有研发具身机器人,现有机器人主要面向...
按下物理AI加速键!香港成全球... 近日,首届香港具身智能产业峰会暨智元APC2026(香港)召开,标志着具身智能从技术炫技正式转向生产...
内塔尼亚胡称将对《纽约时报》提... 新华社耶路撒冷5月14日电(记者庞昕熠 冯国芮)以色列总理办公室14日发表声明称,由于美国《纽约时报...
黄仁勋最后一刻从“局外人”变“... 黄仁勋在最后一刻登上飞往北京的总统专机,从原本的“局外人”瞬间变成“座上宾”。这段场景的背后到底有哪...