匿名用户
这并不是优化器不智能,而是确实没有办法。在 TiDB 中也是一样的行为,这个问题我们被用户问过很多次。TiDB 的行为是以 MySQL 为准,所以这里我以 TiDB 为例作为回答。对于 userid = 10000 这个表达式如何求值?先上代码:点击这里。简单说,就是把 equal 表达式左右两边的值统一为某一种类型后再比较,这个例子中,会都当做(或转换为整数类型),由于 userid 是varchar,那么运算时会做一次 string -> int 的转换,然后再比较两个整数的值是否相等。什么情况可以用索引?能够使用索引的前提是能够构造出索引查询条件,也就是构造出有限个确定性的值,在用这些值去 索引数据结构中查找到对应的 entry(对于 MySQL 是 B-Tree,对于 TiDB 来说,是去 TiKV 中查找)。由于 userid 是 varchar 类型,那么索引数据中存储的 entry 也是字符类型,大家可以想一下哪些字符类型的值和 10000 这个整数相等?实际上有非常多的字符型的值转换为整数后,可以和 10000 这个整数相等,比如 "10000.0"、"10000.00", "0100000".....,也就是无法构造出一个有限的(或者说不大的)查找候选集,去索引中查询,所以并不能用上索引。假设我们换一个场景,userid 是 int 类型,where 条件是 userid = "10000",那么是否可以用索引?大家可以想一下。
2018-12-31 05:50
评论
14
0/140
发布
匿名