select 1 = '1 1' 查出来 1

问题遇到的现象和发生背景

为什么
(1)select 1 = '1 1' 查出来 1
(2)select 1 = '1 3' 查出来 1
(3)select 1 = '3 1' 查出来 0

版本:mysql 8.0.19

当你用一个number和一个字符串去比较的时候
它只比较字符串里最初能转换成number的部分
'1 1'会被转换成1
'1 3'也是1
'3 1'则是3
而'123 1'则是123
如果前面不含数字,比如'h x',则转换成0

mysql中做了隐式转换,'1 1'会被转换成1,因为空格无法转换成数字,所以就直接截取掉空格后面的内容,也就只剩下1了。
实际上你把空格换成其他非数字字符也是一样的效果。