- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
任何人都可以发现我的错误吗?这应该是 SQL 中的合法查询,不是吗?
Unknown column u.usr_auto_key in the ON clause
这是数据库架构:
User: (usr_auto_key, name, etc...)
Setting: (set_auto_key, name etc..)
User_Setting: (usr_auto_key, set_auto_key, value)
这是查询...
SELECT
`u`.`usr_auto_key` AS `u__usr_auto_key`,
`s`.`set_auto_key` AS `s__set_auto_key`,
`u2`.`usr_auto_key` AS `u2__usr_auto_key`,
`u2`.`set_auto_key` AS `u2__set_auto_key`,
`u2`.`value` AS `u2__value`
FROM `User` `u`, `Setting` `s`
LEFT JOIN `User_Setting` `u2` ON `u`.`usr_auto_key` = `u2`.`usr_auto_key`
WHERE (`s`.`sct_auto_key` = 1 AND `u`.`usr_auto_key` = 1 AND admin_property is null)
最佳答案
不要将 SQL-89“逗号样式”连接语法与 SQL-92 JOIN
语法混合。这两种类型的连接操作的优先级存在微妙的问题。
在您的情况下,结果是它在 u
表别名存在之前评估连接条件 LEFT JOIN
。这就是为什么它不知道 u.usr_auto_key
是什么。
您可以通过对所有联接使用 JOIN
语法来纠正此问题:
SELECT
`u`.`usr_auto_key` AS `u__usr_auto_key`,
`s`.`set_auto_key` AS `s__set_auto_key`,
`u2`.`usr_auto_key` AS `u2__usr_auto_key`,
`u2`.`set_auto_key` AS `u2__set_auto_key`,
`u2`.`value` AS `u2__value`
FROM `User` `u` JOIN `Setting` `s`
LEFT JOIN `User_Setting` `u2` ON `u`.`usr_auto_key` = `u2`.`usr_auto_key`
WHERE (`s`.`sct_auto_key` = 1 AND `u`.`usr_auto_key` = 1 AND admin_property is null)
我在您的查询中没有看到 u
和 s
之间有任何连接条件,所以我假设您打算将其作为笛卡尔积?
有关连接的两种语法形式之间的交互的更多详细信息,请参阅页面 http://dev.mysql.com/doc/refman/5.0/en/join.html 上的MySQL 5.0.12 中的连接处理更改部分。
<小时/>回复您的评论:正如我所说,这与运算符优先级有关。如果您有一个包含 FROM A, B JOIN C
的 SQL 查询,那么它会在关注 A
之前评估 B JOIN C
--其中包括分配表别名。因此,如果 B JOIN C
的连接条件使用 A
的表别名,您会收到错误,因为该别名尚不存在。
如果您反转它并运行 B, A JOIN C
,那么它会评估 A JOIN C
的连接条件,即 A
的别名可用且有效(至少在本例中是这样)。
但这是一个脆弱的解决方案,因为您可能还需要一个仅通过重新排序 A
和 B
无法修复的查询。最好停止使用过时的逗号连接语法。然后任何连接表达式都可以访问您的所有表别名,并且您在任何查询中都不会遇到此问题。
关于sql - 这个SQL怎么会错呢?我没看到什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51047583/
我正在使用 Gunicorn 为 Django 应用程序提供服务,它工作正常,直到我将其超时时间从 30 秒更改为 900000 秒,我不得不这样做,因为我有一个用例需要上传和处理一个巨大的文件(过程
我有一个带有非常基本的管道的Jenkinsfile,它可以旋转docker容器: pipeline { agent { dockerfile { args '-u root' } } stag
在学习 MEAN 堆栈的过程中,我遇到了一个问题。每当我尝试使用 Passport 验证方法时,它都不会返回任何响应。我总是收到“localhost没有发送任何数据。ERR_EMPTY_RESPONS
在当今的大多数企业堆栈中,数据库是我们存储所有秘密的地方。它是安全屋,是待命室,也是用于存储可能非常私密或极具价值的物品的集散地。对于依赖它的数据库管理员、程序员和DevOps团队来说,保护它免受所
是否可以创建像图片上那样的边框?只需使用 css 边框属性。最终结果将是没 Angular 盒子。我不想添加额外的 html 元素。我只想为每个 li 元素添加 css 边框信息。 假设这是一个 ul
我是一名优秀的程序员,十分优秀!