blueolive 2019-01-13 16:01 采纳率: 0%
浏览 303

MySQl处理字符时的奇怪问题?

1、数据库中user表id是int类型
图片说明

输入这条查询语句
select * from security.users where id='1 and 1=2';
却能查出结果?
图片说明

mysql不是将1 and 1=2整体与表中的id字段值进行比较吗?为何能够查出结果呢?
求大神指导

  • 写回答

2条回答

  • 流泪熊猫头 2019-01-13 17:51
    关注

    结果说明,真正执行的是 select * from security.users where id=1;
    我的猜测是:'1 and 1=2'是一个字符串,id属性的数据类型是int,在进行where条件判断时,mysql将字符串转为了数值类型,对于字符串中出现的数字,会合理地转为数值类型。空格以及字母会直接截断。
    你可以输入id='1'或者id='1and'等等来验证。

    评论

报告相同问题?

悬赏问题

  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 保护模式-系统加载-段寄存器