简体   繁体   English

UNION与带有大WHERE子句的两个查询

[英]UNION vs two queries with big WHERE clauses

I have two queries that are almost identical - one joining the tables gz_life_groups and gz_life_groups2, the other joining gz_life_floaters and gz_life_floaters2. 我有两个几乎相同的查询-一个连接表gz_life_groups和gz_life_groups2,另一个连接gz_life_floaters和gz_life_floaters2。 I would like to combine both queries into a single query using UNION, but I haven't been able to jump through all the hoops. 我想使用UNION将两个查询合并到一个查询中,但是我还不能跳过所有的障碍。

A brief explanation of what the tables do: Imagine navigating to the URL MySite/life/ursus-maritimus. 表格的简要说明:想象一下导航到URL MySite / life / ursus-maritimus。 Ursus-maritimus matches a value in the database table field Taxon. Ursus-maritimus与数据库表字段Taxon中的值匹配。 So if Ursus maritimus (the polar bear) has been placed in a group titled "White Mammals," it will match values in the table gz_life_groups in the fields Title ("White Mammals") and URL ("white-mammals"). 因此,如果已将Ursus maritimus(北极熊)放在标题为“ White Mammals”的组中,则它将与表gz_life_groups中标题(“ White Mammals”)和URL(“ white-mammals”)中的值匹配。 The field Links simply includes links to related pages. 链接字段仅包含指向相关页面的链接。

QUERY 1 查询1

$Groups = $pdo->prepare("SELECT G2.URL, G2.Taxon, G1.URL, G1.Title, G1.Links
 FROM gz_life_groups2 AS G2
 LEFT JOIN gz_life_groups G1 ON G1.URL = G2.URL
 WHERE Taxon = :Kingdom AND G2.Live = '1'
 OR Taxon = :Phylum AND G2.Live = '1'
 OR Taxon = :Class AND G2.Live = '1'
 OR Taxon = :Order AND G2.Live = '1'
 OR Taxon = :Family AND G2.Live = '1'
 OR Taxon = :Genus AND G2.Live = '1'
 OR Taxon = :MyURL AND G2.Live = '1'
 GROUP BY G1.URL
 Order By G2.N");
$Groups->execute(array(
 'Kingdom'=>$Kingdom,
 'Phylum'=>$Phylum,
 'Class'=>$Class,
 'Order'=>$Order,
 'Family'=>$Family,
 'Genus'=>$Genus,
 'MyURL'=>$MyURL
));

QUERY 2 查询2

$Names = $pdo->prepare("SELECT F2.URL, F2.Taxon, F1.URL, F1.Name, F1.Parent
 FROM gz_life_floaters2 AS F2
 LEFT JOIN gz_life_floaters F1 ON F1.URL = F2.URL
 WHERE Taxon = :Kingdom AND F2.Live = '1'
 OR Taxon = :Phylum AND F2.Live = '1'
 OR Taxon = :Class AND F2.Live = '1'
 OR Taxon = :Order AND F2.Live = '1'
 OR Taxon = :Family AND F2.Live = '1'
 OR Taxon = :Genus AND F2.Live = '1'
 OR Taxon = :MyURL AND F2.Live = '1'
 GROUP BY F1.URL
 Order By F2.N");
$Names->execute(array(
 'Kingdom'=>$Kingdom,
 'Phylum'=>$Phylum,
 'Class'=>$Class,
 'Order'=>$Order,
 'Family'=>$Family,
 'Genus'=>$Genus,
 'MyURL'=>$MyURL
));

This is about as far as my limited knowledge of UNION takes me. 就我对UNION的有限了解带给我的。 I don't know how to add the joins or the WHERE clause... 我不知道如何添加联接或WHERE子句...

$stm = $pdo->prepare("SELECT *
 FROM (
 SELECT G2.URL, G2.Taxon, G1.URL, G1.Title, NULL AS Parent, G1.Links
 FROM gz_life_groups2 AS G2
 UNION ALL 
 SELECT F2.URL, F2.Taxon, F1.URL, F1.Name AS Title, F1.Parent, NULL AS Links
 FROM gz_life_floaters2 AS F2
) AS Combined
 WHERE Combined.URL LIKE :MyURL");
$stm->execute(array(
'MyURL'=>$MyURL
));

You could try writing like this: 您可以尝试这样写:

SELECT G2.URL, G2.Taxon, G1.URL, G1.Title, G1.Links
 FROM gz_life_groups2 AS G2
 LEFT JOIN gz_life_groups G1 ON G1.URL = G2.URL
 WHERE Taxon = :Kingdom AND G2.Live = '1'
 OR Taxon = :Phylum AND G2.Live = '1'
 OR Taxon = :Class AND G2.Live = '1'
 OR Taxon = :Order AND G2.Live = '1'
 OR Taxon = :Family AND G2.Live = '1'
 OR Taxon = :Genus AND G2.Live = '1'
 OR Taxon = :MyURL AND G2.Live = '1'
 GROUP BY G1.URL

UNION

SELECT F2.URL, F2.Taxon, F1.URL, F1.Name, F1.Parent
 FROM gz_life_floaters2 AS F2
 LEFT JOIN gz_life_floaters F1 ON F1.URL = F2.URL
 WHERE Taxon = :Kingdom AND F2.Live = '1'
 OR Taxon = :Phylum AND F2.Live = '1'
 OR Taxon = :Class AND F2.Live = '1'
 OR Taxon = :Order AND F2.Live = '1'
 OR Taxon = :Family AND F2.Live = '1'
 OR Taxon = :Genus AND F2.Live = '1'
 OR Taxon = :MyURL AND F2.Live = '1'
 GROUP BY F1.URL

If the value of :Phylum, for example, is different for the first and the second part of the UNION , name the 2nd :Phylum to :PylumBelowUnion or something like that and pass an array with values for both :Phylum :PhylumBelowUnion. 例如,如果:Phylum的值在UNION的第一部分和第二部分中不同,则将第二个:Phylum命名为:PylumBelowUnion或类似的名称,并传递一个同时包含:Phylum:PhylumBelowUnion值的数组。

I'd also recommend using brackets with your and s and or s like so: 我还建议您在andor使用方括号,如下所示:

(Taxon = :Kingdom AND F2.Live = '1') OR
(Taxon = :MyURL AND F2.Live = '1') ...

I am assuming that's what you want. 我假设这就是您想要的。 If not, ignore the advice above. 如果不是,请忽略上面的建议。

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM