mysql 这句话为什么把所有的记录都查出来了? username是字符串格式

新手上路,请多包涵

mysql select * from user where username in (0)
这句话为什么把所有的记录都查出来了? username是字符串格式

阅读 1.2k
2 个回答

字符串跟数字的比较是转换成数字进行的。非数字也不以数字开头的串都会转换成 0 ,正好跟 0 相等,username in (0) 判断就成功了。

select * from user where username in ("0")

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题