问题遇到的现象和发生背景
为什么
(1)select 1 = '1 1' 查出来 1
(2)select 1 = '1 3' 查出来 1
(3)select 1 = '3 1' 查出来 0
版本:mysql 8.0.19
为什么
(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