MySQL WHERE 条件下仅剩字段,为何仍能返回数据?

mysql where 条件下仅剩字段,为何仍能返回数据?

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 条件下仅剩字段,为何仍能返回数据?的详细内容,更多请关注其它相关文章!