qq_43304875 2023-01-09 14:24 采纳率: 40%
浏览 33
已结题

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

  • 写回答

3条回答 默认 最新

  • 於黾 2023-01-09 14:29
    关注

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

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 1月17日
  • 已采纳回答 1月9日
  • 创建了问题 1月9日