在执行UNION时应用WHERE子句

时间:2016-04-15 07:55:02

标签: php mysql database

我正在努力让这个MySQL查询工作。我有两张桌子:

表1

TYPE | NAME | LAT | LON | ICON

表2

ID | UID | NAME | LAT | LON | ICON

我正在尝试从表1中选择所有结果,并仅从表2中选择一些结果。我正在尝试将WHERE子句应用于表2,但它似乎不起作用。

我阅读了文档,它说要UNION工作,列数必须相同。那么我怎样才能从两个表中选择相同数量的列来返回,但是只能通过该表上的列过滤第二个表?

我的(伪)查询:

(SELECT name,lat,lon,icon 
FROM Table1)

UNION 

(SELECT name,lat,lon,icon 
FROM Table2
WHERE uid ="1") 

1 个答案:

答案 0 :(得分:1)

SELECT * FROM table1
UNION
SELECT
    NULL AS `type`,
    `name`,
    `lat`,
    `long`,
    `icon`
FROM table2 WHERE uid = 1

http://www.sqlfiddle.com/#!9/0a942/8

这将从table1中选择所有内容,并且仅从table2中选择uid = 1

只有两个行集具有完全相同的列时,才能执行UNION。由于type中没有table2列,我们选择NULL并将其命名为type,以便我们可以UNION