带有多个条件的Mysql右连接不起作用

问题描述 投票:-1回答:1

我有两个表table1和table2,当将table2与table1正确连接时,我没有得到该行。在这里,我还附加了小提琴链接

Fiddle ink

CREATE TABLE `table1` (
 `orderid` int(11) NOT NULL AUTO_INCREMENT,
 PRIMARY KEY (`orderid`)
);
CREATE TABLE `table2` ( `fields_id` INT NOT NULL AUTO_INCREMENT , `table1_order_id` INT(11) NOT NULL , `field_value` VARCHAR(100) NOT NULL , `fname` VARCHAR(100) NOT NULL , PRIMARY KEY (`fields_id`)) ENGINE = InnoDB;

INSERT INTO `table1` (`orderid`) VALUES (1), (2), (3), (4), (5), (6);
INSERT INTO `table2` (`fields_id`, `table1_order_id`, `field_value`, `fname`) VALUES (NULL, '1', 'karthi', 'name');
INSERT INTO `table2` (`fields_id`, `table1_order_id`, `field_value`, `fname`) VALUES (NULL, '2', 'karthi', 'name');
INSERT INTO `table2` (`fields_id`, `table1_order_id`, `field_value`, `fname`) VALUES (NULL, '3', 'selva', 'name');
INSERT INTO `table2` (`fields_id`, `table1_order_id`, `field_value`, `fname`) VALUES (NULL, '1', 'salem', 'city');
INSERT INTO `table2` (`fields_id`, `table1_order_id`, `field_value`, `fname`) VALUES (NULL, '2', 'chennai', 'city');
INSERT INTO `table2` (`fields_id`, `table1_order_id`, `field_value`, `fname`) VALUES (NULL, '3', 'mumbai', 'city');

select table1.*
from table1 
right JOIN table2 ON (
        table2.table1_order_id = table1.orderid 
        AND 
            ( table2.field_value LIKE '%karthi%' 
            AND table2.fname = 'name' ) 
        AND ( 
            table2.field_value LIKE '%salem%' 
            AND table2.fname = 'city' 
        ) 

    ) 

    where 1 group by table1.orderid

上面我写了选择查询,但返回空结果但我希望输出如下所示,

订单ID1

mysql join
1个回答
1
投票

您必须将AND子句更改为OR子句,您将获得两条记录,如下所示:

select table1.*
from table1 
right JOIN table2 ON
        table2.table1_order_id = table1.orderid 
    where 
            ( table2.field_value LIKE '%karthi%' 
            AND table2.fname = 'name' ) 
        OR ( 
            table2.field_value LIKE '%salem%' 
            AND table2.fname = 'city' 
        ) 

    group by table1.orderid
© www.soinside.com 2019 - 2024. All rights reserved.