美文网首页
mysql查询语句类型转换相关

mysql查询语句类型转换相关

作者: xdlkc | 来源:发表于2017-08-14 18:34 被阅读40次

    执行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直接返回结果

    相关文章

      网友评论

          本文标题:mysql查询语句类型转换相关

          本文链接:https://www.haomeiwen.com/subject/ctfprxtx.html