- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在我输入所有这些之前,我已经尝试并尝试从此处的其他线程和搜索谷歌找到解决方案。但我似乎无法得到答案。我认为自己的 SQL 相当不错,但我似乎根本无法解决这个问题。
我目前有两个表:
我正在尝试获取 ref_departments.id
和 ref_departments.department_name
的数组,它们将用作前端的下拉列表以填充 company_department_norm
表。在这一点上最好指出的是,我在创建下拉列表等方面没有技术问题 - 它是在 Yii 框架中构建的,实际的下拉列表本身已经到位。我的问题是确定正确的 SQL 语句以返回我想要填充下拉列表的数据(我将使用 Yii 的 Chtml 帮助程序类)。
我要创建的 SELECT
语句的第一个条件是对 ref_departments
表的查询将仅选择 中的值的行在
(PK) 列。这样做是为了在列表中仅提供有效选项。我有这个查询工作,它看起来像这样......company_department_norm.department_id
列中找不到 id
SELECT RD.id, RD.department_name FROM ref_departments RD
LEFT OUTER JOIN company_department_norm CDN
ON (CDN.department_id = RD.id)
WHERE (CDN.department_id IS NULL)
额外的完整性/数据验证也将在后端完成(在 Yii 模型类中)。
下一步是我完全坚持的部分。在 company_department_norm
的 Yii 模型中,company_id
字段表示公司的 FK(如上所示)。这将作为参数传递到查询中以向查询添加附加条件,以便 JOIN
语句将仅匹配右表 (company_department_name
) 中的行,其中 company_id
与从模型传递的 company_id
相同。出于测试目的,我只是尝试使用整数 1 的 company_id
硬编码到 SQL 语句中。然而,对于我的生活,我似乎无法弄清楚如何做到这一点。
我尝试使用以下方法修改上述查询:-
LEFT OUTER JOIN (SELECT * FROM company_department_norm WHERE
company_department_norm.company_id = 1) CDN
但是,这似乎根本无法过滤出正确的表格。
谁能帮我解决这个问题?我可以想象,比我更有经验的 SQL 用户能够很快确定解决方案,但我已经绞尽脑汁好几个小时试图解决这个问题!
最佳答案
您可以将 company_id 条件放在 ON 子句中:
SELECT RD.id, RD.department_name FROM ref_departments RD
LEFT OUTER JOIN company_department_norm CDN
ON (CDN.department_id = RD.id AND CDN.company_id = 1)
WHERE (CDN.department_id IS NULL)
这会返回尚未代表公司 1 的任何部门,而您的第一个查询返回尚未代表任何公司的任何部门。
关于您的评论:根据您的示例数据,此查询不会显示使用 company_id 条件与否之间的任何区别,因为两个部门都代表公司 1。
我已经在 MySQL 5.5 上测试过了,它运行良好。这是另一个示例,其中包含更多数据,可以更好地展示:
use test;
drop table if exists ref_departments;
create table ref_departments (
id int primary key,
department_name varchar(20)
);
insert into ref_departments values
(1, 'Accounts'),
(2, 'HR'),
(3, 'IT');
drop table if exists company_department_norm;
create table company_department_norm (
id int primary key,
company_id int,
department_name varchar(20),
department_id int
);
insert into company_department_norm values
(1, 1, 'Accounting', 1),
(2, 1, 'HR', 2),
(3, 2, 'Accounts', NULL),
(4, 2, 'HR', NULL),
(5, 2, 'IT', 3);
现在查询不在公司 1 的部门,它正确显示“IT”:
SELECT RD.id, RD.department_name FROM ref_departments RD
LEFT OUTER JOIN company_department_norm CDN
ON (CDN.department_id = RD.id AND CDN.company_id = 1)
WHERE (CDN.department_id IS NULL);
+----+-----------------+
| id | department_name |
+----+-----------------+
| 3 | IT |
+----+-----------------+
现在查询不在公司 2 中的部门。即使公司 2 名称 Accounts 和 HR,它也没有加入条件所基于的数字 department_id。所以它认为这两个部门不匹配。
SELECT RD.id, RD.department_name FROM ref_departments RD
LEFT OUTER JOIN company_department_norm CDN
ON (CDN.department_id = RD.id AND CDN.company_id = 2)
WHERE (CDN.department_id IS NULL);
+----+-----------------+
| id | department_name |
+----+-----------------+
| 1 | Accounts |
| 2 | HR |
+----+-----------------+
如果您得到一些其他结果,您要么没有按照我描述的那样使用查询,要么您的数据与您描述的不一样。
关于mysql - 在右表上使用条件 SELECT 的条件 LEFT INNER JOIN 查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14896076/
IE 似乎在来自未压缩的 raphaeljs 1.4.7 的以下第 2207 行(当然,在我的代码的上下文中): gs.left != (t = left + "px") && (gs.left =
这是在操纵 $("#mydiv").position().left 还是 $("#mydiv").offset().left? $("#mydiv").animate({"left":"-100"},
这个问题在这里已经有了答案: why left+(right-left)/2 will not overflow? (7 个答案) 关闭 1 年前。 在二分搜索 while 循环中: left, r
这个问题在这里已经有了答案: why left+(right-left)/2 will not overflow? (7 个答案) 关闭 1 年前。 在二分搜索 while 循环中: left, r
我有一个 Segment 类和一个这样的段数组: private static class Segment { int number, type; Segment(in
我有一个查询,它在子选择上执行 LEFT JOIN。此查询在高负载环境中运行,并在设定的要求内执行。查询(高度简化)如下所示: SELECT table_A.pKey , table_A.uKey
我在 SO 中看到一些创建 multilanguage websites in JavaScript 的好建议包括 this article on JavaScript internationaliz
我已经使用它年了,所以是时候全面了解它了。假设这样的查询: SELECT * FROM a LEFT JOIN b ON foo... LEFT JOIN c ON bar... document
我正在尝试对搜索框执行以下 MySql 查询。我试图返回“专辑”信息(标题等),同时包含该专辑中第一张图片的缩略图。但是,我必须查找两个表才能获取图像信息。首先,photos_albums包含该相册中
我有 2 个表,我想 LEFT JOIN 并过滤 LEFT 表上的结果。这些表是: -product_table,包含列 id 和 product_name -order_table,包含列 id、p
我理解 Left Join 应该做什么吗? 我有一个问题。将其称为查询 A。它返回 19 条记录。 我有另一个查询,查询 B。它返回 1,400 条记录。 我将查询 B 作为左连接插入到查询 A 中,
我正在使用 left: auto;希望重写left: 0;但它不起作用(请参阅 jsfiddle )-我想要 居中对齐。 HTML:
为什么这不起作用?我已经分配了一堆带有 float:left 的 div,并希望设置第一个元素的位置,然后用它更新所有 sibling 的位置。 例如,我将第一个元素的 css 设置为 left:50
这应该是非常基本的 CSS,但无论我尝试什么,该死的 div 就是不会去它应该去的地方! 这是 HTML: Registe-se Nome:
我在一个 div 中嵌套了一个 div。我正在尝试显示一些文本并且有效。然而,我想要的是文本居中对齐,即它有一个 left: -50%。但它什么都不做。但是当我执行类似 left: 20px 的操作时
我有一个包含跟踪数据的表格。在其他值中,该表具有列 traffic_medium、traffic_source 和 traffic_campaign。这些列有时确实包含 (none) 或 null 作
我正在尝试 中的代码。 在 GHC 版本 6.10.4 上: data ParseState = ParseState { string :: String } deriving (Show) n
我在使用用于显示自定义配置文件字段和任何(可选)对应值的 SQL 查询时遇到问题。 这是我正在使用的 SQL 查询: SELECT pf.`id`, pf.`name`, pv.`value` FRO
我目前制作了一个包含侧边栏和内容的容器,但是当我向侧边栏添加的文本多于向容器添加的文本时,第二个侧边栏会稍微 float 到一边。这些是我正在使用的代码。 HTML: Pl
这个问题在这里已经有了答案: Difference between margin and padding? (25 个答案) 关闭 5 年前。
我是一名优秀的程序员,十分优秀!