我有两个表table1和table2,当将table2与table1正确连接时,我没有得到该行。在这里,我还附加了小提琴链接
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
您必须将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