MySQL中where后跟字段条件的疑惑
MySQL中,select from where 查询语句,即使where后的条件仅剩一个字段,也能返回数据,但仅限于数字开头的结果。这不禁让人好奇,在这种情况下,MySQL到底是基于什么条件进行过滤的。
根据MySQL文档,where后的条件是一个表达式,如果对于每条待选行,表达式的值为真,则该行会被选择。换句话说,where后的字段仅当其可以转换为true时,才会成为有效条件。
在示例中,uuid是一个唯一标识符字段,它可以转换为true。因此,MySQL将where后的uuid视为一个表达式的值,对其进行求值,并返回满足uuid可以转换为true的记录。
值得注意的是,这种方法与Oracle不同。在Oracle中,如果where后的条件仅剩一个字段,它会自动报错。而MySQL则允许这种表达式的使用,并返回满足条件的数据。
以上就是MySQL WHERE 条件下仅剩字段,为何仍能返回数据?的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号