mysql左外连接where子句

piwo6bdm  于 2021-06-19  发布在  Mysql
关注(0)|答案(3)|浏览(585)

我正在尝试使用以下mysql查询:

SELECT *
FROM top_lines t
LEFT OUTER JOIN last_24_topline AS l ON l.`member_no` = t.`member_no` 
    AND l.`mfg` = t.`line_no`
WHERE l.account_no = 32049 OR l.account_no IS NULL

但是这不返回任何行,因为在最后一行中没有匹配的帐户行。据我所知并阅读过的所有内容,此查询仍应返回顶部行中的所有行,即使最后一行中没有匹配的行,因为我正在检查值或null,但它不是。mysql(5.7.2)中是否有任何选项或设置会导致这种行为?仅供参考,此查询按预期工作:

SELECT *
FROM top_lines t
LEFT OUTER JOIN last_24_topline l ON l.`member_no` = t.`member_no` 
    AND l.`mfg` = t.`line_no`
    AND l.`account_no` = 32049

但是,我不能使用这个构造,因为我使用的是实体框架,您只能传入列,不能向联接传递值

CREATE TABLE `last_24_topline` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT,
  `member_no` varchar(30) NOT NULL,
  `branch_no` int(11) DEFAULT NULL,
  `employee_no` varchar(25) DEFAULT NULL,
  `account_no` varchar(25) DEFAULT NULL,
  `salesperson_name` varchar(255) DEFAULT NULL,
  `customer_name` varchar(255) DEFAULT NULL,
  `mfg` varchar(5) DEFAULT NULL,
  `mfg_description` varchar(255) DEFAULT NULL,
  `last_three` decimal(10,2) DEFAULT '0.00',
  `last_twelve` decimal(10,2) DEFAULT '0.00',
  `ly_last_three` decimal(10,2) DEFAULT '0.00',
  `ly_last_twelve` decimal(10,2) DEFAULT '0.00',
  PRIMARY KEY (`id`),
  KEY `ix_branch_no` (`branch_no`),
  KEY `ix_employee_no` (`employee_no`),
  KEY `ix_member_line_account` (`member_no`,`mfg`,`account_no`),
  KEY `ix_member_line` (`member_no`,`mfg`),
  KEY `ix_account_no` (`account_no`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8

CREATE TABLE `top_lines` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `member_no` varchar(30) NOT NULL,
  `line_no` varchar(5) NOT NULL,
  `line_description` varchar(255) NOT NULL,
  PRIMARY KEY (`id`),
  KEY `ix_line_no` (`member_no`,`line_no`)
) ENGINE=InnoDB AUTO_INCREMENT=41 DEFAULT CHARSET=latin1

insert  into `top_lines`(`id`,`member_no`,`line_no`,`line_description`) values (1,'520','772','FED ROTOR/DRUM');
insert  into `top_lines`(`id`,`member_no`,`line_no`,`line_description`) values (2,'520','952','FED SST CERAMIC');
insert  into `top_lines`(`id`,`member_no`,`line_no`,`line_description`) values (3,'520','954','FED SST FRICTION');
insert  into `top_lines`(`id`,`member_no`,`line_no`,`line_description`) values (4,'520','162','EVS FRICTION');

INSERT INTO `last_24_topline` (`id`, `member_no`, `branch_no`, `employee_no`, `account_no`, `salesperson_name`, `customer_name`, `mfg`, `mfg_description`, `last_three`, `last_twelve`, `ly_last_three`, `ly_last_twelve`) VALUES('1','520','0','10856','463854','FORD, JAMES,','JIFFY LUBE','459','FEDERATED AIR FILTER','0.00','15.21','0.00','0.00');
INSERT INTO `last_24_topline` (`id`, `member_no`, `branch_no`, `employee_no`, `account_no`, `salesperson_name`, `customer_name`, `mfg`, `mfg_description`, `last_three`, `last_twelve`, `ly_last_three`, `ly_last_twelve`) VALUES('2','520','0','10856','463854','FORD, JAMES,','JIFFY LUBE','460','FILTERS','0.00','0.00','0.00','16.48');
INSERT INTO `last_24_topline` (`id`, `member_no`, `branch_no`, `employee_no`, `account_no`, `salesperson_name`, `customer_name`, `mfg`, `mfg_description`, `last_three`, `last_twelve`, `ly_last_three`, `ly_last_twelve`) VALUES('3','520','0','10856','463854','FORD, JAMES,','JIFFY LUBE','863','SMP T SERIES','0.00','0.00','0.00','50.67');

我希望,即使最后一个\u24\u顶行中没有匹配的数据,第一个查询也会生成一个结果集,其中包含顶行中的所有行,最后一个\u24\u顶行中的列的值为null。
预期结果:

因此,在另一个数据库中创建相同的模式并只插入上面提供的示例数据,我就得到了预期的结果。我正在进一步测试,将整行复制到第二个数据库中,以查看它是否仍然提供预期的结果。
更新将所有数据复制到新表中会导致问题再次出现。我正试图把问题缩小到最低限度。

5vf7fwbs

5vf7fwbs1#

也尝试检测空字符串,可能字段不是空的,而是空字符串。

SELECT *
FROM
    top_lines t
LEFT JOIN
    last_24_topline AS l ON l.member_no = t.member_no AND l.mfg = t.line_no
WHERE
    (l.account_no = '' OR l.account_no = '32049' OR l.account_no IS NULL)

如果您需要更多帮助,我需要“table last\u 24\u topline”的示例数据和连接后的预期输出。
作为第二次尝试,您可以使用以下方法:

SELECT *
FROM
    top_lines t
LEFT JOIN
    last_24_topline AS l ON l.member_no = t.member_no AND l.mfg = t.line_no
WHERE
    l.id IS NULL
OR
    (l.id IS NOT NULL AND l.account_no = '32049')
1cosmwyk

1cosmwyk2#

在联接中没有帐号的查询中,联接确实匹配上一个\u 24\u topline表中的行,但它与where子句中的帐号不匹配,因此它被过滤掉,并且不被视为上一个\u 24\u topline表中没有匹配行的行。
例如,上一行表中的这一行

将匹配最后一行的\u 24 \u顶行

但是这两个都将被过滤掉,因为帐户\u no与where子句中的内容不匹配: WHERE l.account_no = 32049 OR l.account_no IS NULL 在联接中带有检查帐户\u no的查询仍将匹配上一行中的行,但不会有上一行中的匹配行,因此您将获得上一行数据为空的上一行。

jm81lzqq

jm81lzqq3#

使用联接中涉及的列,而不是 l.account_no 这样,如果左表中没有匹配的行,则返回顶部行中的行。

SELECT *
FROM top_lines t
LEFT OUTER JOIN last_24_topline AS l ON l.`member_no` = t.`member_no`
       AND l.`mfg` = t.`line_no`
WHERE l.account_no = 32049 OR l.`member_no` IS NULL

或者,将帐号过滤器直接放入join中

SELECT *
FROM top_lines t
LEFT OUTER JOIN last_24_topline AS l ON l.`member_no` = t.`member_no`
       AND l.`mfg` = t.`line_no`
       AND l.account_no = 32049

相关问题