设为首页 收藏本站
查看: 622|回复: 0

[经验分享] mysql 隐式转换问题

[复制链接]

尚未签到

发表于 2018-10-2 06:56:47 | 显示全部楼层 |阅读模式
  mysql隐式转换问题,特别在我们进行sql编写,sql优化的时候应该特别注意,可是大部分人都只知道mysql隐式转换,具体描述的时候却是有点模糊!
DSC0000.jpg

  我们看上图,yhtest 表,第三列为c、varchar 类型,表中4行数据,当我们使用select * from yhtest where c=0; 进行查询的时候,有三个warning!
DSC0001.jpg

  今天我们就从这三个warning 说起,后面的大部分内容可以解释为啥会有这三个warnings!
  转换原则:当我们在使用where条件查询的时候,字段类型和赋值类型不一致时,都将转换成整型! 这样一个描述其实是比较模糊的,下面我们具体来看。上图中字段类型为varchar 字符串类型,但是查询条件为c=0 整形,需要将字段内容都转换为整型,转换方式为:
  1)纯字符串内容,则直接转换为0  ‘abc’ 将直接被转换为0
  2)含有以数字开头的字符串 ,则会进行截取处理,截取至不是数字的字符串为止,比如‘4abc’ 将 转换为4    ,‘04abc’ 被转换为‘04’ 但是这个在匹配c=4的时候,是会被匹配到的
DSC0002.jpg

  3)如果是纯数字字符串,那么将直接转换为对应的整形,比如‘4’ 将直接转换为4
  4)以字符开头,数字结尾的,还是将转换为0
  这样我们再看开头所报出的warnings ,顿时觉得合理了
  很多sql优化的文章中强调:字符串一定记得在where条件中加引号,原因也正是在这里,下面我们看例子
DSC0003.jpg

  执行 select from  yhtest  where c=4 的结果和执行计划如下:
DSC0004.jpg

  执行select  from  yhtest  where c='4' 结果和执行计划如下:
DSC0005.jpg

  通过执行计划我们看到,第一种where条件后面字段类型 和赋值类型不一致,隐式转换,也没有用到c列上的索引。第二种不存在隐式转换,使用了c列的索引,二者的查询结果也不一样!
  上述隐式转换,大部分时候,我们需要用来避免隐式转换带来的不走索引,全表扫描,带来的sql性能问题,但是在数据少的时候,我们可以用来做一些特别操作,比如让'abcdefg'=0?


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.iyunv.com/thread-607300-1-1.html 上篇帖子: mysql 5.7使用别名问题 下篇帖子: MySQL常见错误问答(2)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表