mysql查询语句类型转换相关

执行show语句看一下一个普通表的结构:

SHOW CREATE TABLE test.user;

输出:

CREATE TABLE `user` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '自增主键',
  `name` varchar(20) NOT NULL,
  `age` int(11) DEFAULT NULL,
  `sex` varchar(10) NOT NULL,
  `card` bigint(20) NOT NULL,
  PRIMARY KEY (`id`),
  KEY `card` (`card`),
  KEY `name` (`name`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='用户信息表'

注意到这里id字段是bigint类型,那么如果我查询记录时where条件判断id等于一个字符串会怎样呢?来试一下:

SELECT * FROM test.user WHERE id = '1-fad';

输出:


可以发现竟然查出来了,而且简单对比一下,感觉查出来的id就是字符串中的1啊,那么是为什么呢,其实mysql针对这种需要类型转换的时候进行了隐式转换,像字符串转为int呢方法就是将字符串从前向后截取到非数字的地方,然后把后面全部改成0并求和,相当于转化的值就是第一个非数字的位置前面代表的数字.
这里后来也发现了一个其他的问题,就是在查看执行计划时发现如果截取的数字超过字段对应的类型的话是不会查询的,来比较一下:
在范围内的情况:

EXPLAIN SELECT * FROM test.user WHERE id = '1-fad';

超过范围的情况:

EXPLAIN SELECT * FROM test.user WHERE id = '1231231231231-fad';

结果显而易见,各项都是空,mysql直接返回结果

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 什么是数据库? 数据库是存储数据的集合的单独的应用程序。每个数据库具有一个或多个不同的API,用于创建,访问,管理...
    chen_000阅读 9,467评论 0 19
  • mysql性能优化-慢查询分析、优化索引和配置 分类:Mysql/postgreSQL 目录 一、优化概述 二、查...
    CaesarXia阅读 8,068评论 1 46
  • 系统层面(基本不用动,看了下,买的云服务器基本都已经优化过了) 内核相关参数(/etc/sysctl.conf) ...
    神奇大叶子阅读 6,190评论 0 4
  • 前几天在个人公众号上推送了一篇简短的文字,大概是论慢跑和跳绳减肥的区别。文字本身其实并没有什么涵养,除了借机表达了...
    白羊菌阅读 3,240评论 2 5
  • 前言 最近看项目代码,发现里面有大量的断言。已经看不懂了,偷偷百度学习一下。 百度搜索 断言:断言表示为一些...
    kikey阅读 4,359评论 0 49