mysql中where后跟字段条件的疑惑
MySQL中,select from where 查询语句,即使where后的条件仅剩一个字段,也能返回数据,但仅限于数字开头的结果。这不禁让人好奇,在这种情况下,MySQL到底是基于什么条件进行过滤的。
根据MySQL文档,where后的条件是一个表达式,如果对于每条待选行,表达式的值为真,则该行会被选择。换句话说,where后的字段仅当其可以转换为true时,才会成为有效条件。
在示例中,uuid是一个唯一标识符字段,它可以转换为true。因此,MySQL将where后的uuid视为一个表达式的值,对其进行求值,并返回满足uuid可以转换为true的记录。
值得注意的是,这种方法与oracle不同。在Oracle中,如果where后的条件仅剩一个字段,它会自动报错。而MySQL则允许这种表达式的使用,并返回满足条件的数据。
© 版权声明
文章版权归作者所有,未经允许请勿转载。
THE END