Die erste Anweisung in UNION gibt vier Spalten zurück:
SELECT b.id AS id,
b.pid AS pid,
b.message AS message,
b.date AS date
FROM wall_posts AS b
Der zweite gibt sechs zurück , da das * so erweitert wird, dass es alle Spalten von WALL_POSTS
enthält :
SELECT b.id,
b.date,
b.privacy,
b.pid.
b.uid message
FROM wall_posts AS b
Die UNION
und UNION ALL
Operatoren erfordern Folgendes:
- In allen Anweisungen, aus denen die UNION-Abfrage besteht, ist dieselbe Anzahl von Spalten vorhanden
- Die Datentypen müssen an jeder Position/Spalte übereinstimmen
Verwendung:
FROM ((SELECT b.id AS id,
b.pid AS pid,
b.message AS message,
b.date AS date
FROM wall_posts AS b
JOIN Friends AS f ON f.id = b.pid
WHERE f.buddy_id = '1' AND f.status = 'b'
ORDER BY date DESC
LIMIT 0, 10)
UNION
(SELECT id,
pid,
message,
date
FROM wall_posts
WHERE pid = '1'
ORDER BY date DESC
LIMIT 0, 10))