Php mysql query union

MySQL UNION Operator

The UNION operator is used to combine the result-set of two or more SELECT statements.

  • Every SELECT statement within UNION must have the same number of columns
  • The columns must also have similar data types
  • The columns in every SELECT statement must also be in the same order

UNION Syntax

UNION ALL Syntax

The UNION operator selects only distinct values by default. To allow duplicate values, use UNION ALL :

Note: The column names in the result-set are usually equal to the column names in the first SELECT statement.

Demo Database

In this tutorial we will use the well-known Northwind sample database.

Below is a selection from the «Customers» table:

And a selection from the «Suppliers» table:

SupplierID SupplierName ContactName Address City PostalCode Country
1 Exotic Liquid Charlotte Cooper 49 Gilbert St. London EC1 4SD UK
2 New Orleans Cajun Delights Shelley Burke P.O. Box 78934 New Orleans 70117 USA
3 Grandma Kelly’s Homestead Regina Murphy 707 Oxford Rd. Ann Arbor 48104 USA

SQL UNION Example

The following SQL statement returns the cities (only distinct values) from both the «Customers» and the «Suppliers» table:

Example

Note: If some customers or suppliers have the same city, each city will only be listed once, because UNION selects only distinct values. Use UNION ALL to also select duplicate values!

Читайте также:  Valid xml name java

SQL UNION ALL Example

The following SQL statement returns the cities (duplicate values also) from both the «Customers» and the «Suppliers» table:

Example

SQL UNION With WHERE

The following SQL statement returns the German cities (only distinct values) from both the «Customers» and the «Suppliers» table:

Example

SELECT City, Country FROM Customers
WHERE Country=’Germany’
UNION
SELECT City, Country FROM Suppliers
WHERE Country=’Germany’
ORDER BY City;

SQL UNION ALL With WHERE

The following SQL statement returns the German cities (duplicate values also) from both the «Customers» and the «Suppliers» table:

Example

SELECT City, Country FROM Customers
WHERE Country=’Germany’
UNION ALL
SELECT City, Country FROM Suppliers
WHERE Country=’Germany’
ORDER BY City;

Another UNION Example

The following SQL statement lists all customers and suppliers:

Example

SELECT ‘Customer’ AS Type, ContactName, City, Country
FROM Customers
UNION
SELECT ‘Supplier’, ContactName, City, Country
FROM Suppliers;

Notice the «AS Type» above — it is an alias. SQL Aliases are used to give a table or a column a temporary name. An alias only exists for the duration of the query. So, here we have created a temporary column named «Type», that list whether the contact person is a «Customer» or a «Supplier».

Источник

Php mysql query union

Оператор UNION позволяет обединить две однотипных выборки. Эти выборки могут быть из разных таблиц или из одной и той же таблицы. Формальный синтаксис объединения:

SELECT_выражение1 UNION [ALL] SELECT_выражение2 [UNION [ALL] SELECT_выражениеN]

Например, пусть в базе данных будут две отдельные таблицы для клиентов банка (таблица Customers) и для сотрудников банка (таблица Employees):

CREATE TABLE Customers ( Id INT AUTO_INCREMENT PRIMARY KEY, FirstName VARCHAR(20) NOT NULL, LastName VARCHAR(20) NOT NULL, AccountSum DECIMAL ); CREATE TABLE Employees ( Id INT AUTO_INCREMENT PRIMARY KEY, FirstName VARCHAR(20) NOT NULL, LastName VARCHAR(20) NOT NULL ); INSERT INTO Customers(FirstName, LastName, AccountSum) VALUES ('Tom', 'Smith', 2000), ('Sam', 'Brown', 3000), ('Mark', 'Adams', 2500), ('Paul', 'Ins', 4200), ('John', 'Smith', 2800), ('Tim', 'Cook', 2800); INSERT INTO Employees(FirstName, LastName) VALUES ('Homer', 'Simpson'), ('Tom', 'Smith'), ('Mark', 'Adams'), ('Nick', 'Svensson');

Здесь мы можем заметить, что обе таблицы, несмотря на наличие различных данных, могут характеризоваться двумя общими атрибутами — именем (FirstName) и фамилией (LastName). Выберем сразу всех клиентов банка и его сотрудников из обеих таблиц:

SELECT FirstName, LastName FROM Customers UNION SELECT FirstName, LastName FROM Employees;

Здесь из первой таблицы выбираются два значения — имя и фамилия клиента. Из второй таблицы Employees также выбираются два значения — имя и фамилия сотрудников. То есть при объединении количество выбираемых столбцов и их тип совпадают для обеих выборок.

UNION в MySQL

При этом названия столбцов объединенной выборки будут совпадать с названия столбцов первой выборки. И если мы захотим при этом еще произвести сортировку, то в выражениях ORDER BY необходимо ориентироваться именно на названия столбцов первой выборки:

SELECT FirstName AS FName, LastName FROM Customers UNION SELECT FirstName, LastName FROM Employees ORDER BY FName DESC;

В данном случае каждая выборка имеет по столбцу FName из первой выборки. Тем не менее при сортировке будет учитываться и значение столбца FirstName из второй выборки:

Сортировка в UNION в MySQL

Если же в одной выборке больше столбцов, чем в другой, то они не смогут быть объединены. Например, в следующем случае объединение завершится с ошибкой:

SELECT FirstName, LastName, AccountSum FROM Customers UNION SELECT FirstName, LastName FROM Employees;

Если оба объединяемых набора содержат в строках идентичные значения, то при объединении повторяющиеся строки удаляются. Например, в случае с таблицами Customers и Employees сотрудники банка могут быть одновременно его клиентами и содержаться в обеих таблицах. При объединении в примерах выше всех дублирующиеся строки удалялись. Если же необходимо при объединении сохранить все, в том числе повторяющиеся строки, то для этого необходимо использовать оператор ALL :

SELECT FirstName, LastName FROM Customers UNION ALL SELECT FirstName, LastName FROM Employees ORDER BY FirstName;

Обединение повторяющихся строк в MySQL

Объединять выборки можно и из одной и той же таблицы. Например, в зависимости от суммы на счете клиента нам надо начислять ему определенные проценты:

SELECT FirstName, LastName, AccountSum + AccountSum * 0.1 AS TotalSum FROM Customers WHERE AccountSum < 3000 UNION SELECT FirstName, LastName, AccountSum + AccountSum * 0.3 AS TotalSum FROM Customers WHERE AccountSum >= 3000;

В данном случае если сумма меньше 3000, то начисляются проценты в размере 10% от суммы на счете. Если на счете больше 3000, то проценты увеличиваются до 30%.

Источник

Как использовать вложенный запрос с UNION?

Оказалось что MySQL не поддерживает UNION во вложенных запросах. 🙁
Появилась идея сохранять результат (SELECT `id`, 0 AS `count`, ‘foo’ AS `f` FROM `table2` [куча where] UNION SELECT `id`, `count` AS `count`, ‘bar’ AS `f` FROM `table3` LIMIT 1); в переменную и потом как то пихать эту переменную в INSERT. Что то типа:

SET @record = (SELECT `id`, 0 AS `count`, 'foo' AS `f` FROM `table2` [куча where] UNION SELECT `id`, `count` AS `count`, 'bar' AS `f` FROM `table3` LIMIT 1); INSERT INTO `table` (`id`, `count`, `f`) @record;

0xD34F

INSERT INTO `table` (`id`, `count`, `f`) SELECT * FROM ( (SELECT `id`, 0 AS `count`, 'foo' AS `f` FROM `table2` [куча where]) UNION (SELECT `id`, `count` AS `count`, 'bar' AS `f` FROM `table3` LIMIT 1) ) AS t;

UPD. Вообще, должно работать и без дополнительного SELECT’а:

INSERT INTO `table` (`id`, `count`, `f`) (SELECT `id`, 0 AS `count`, 'foo' AS `f` FROM `table2` [куча where]) UNION (SELECT `id`, `count` AS `count`, 'bar' AS `f` FROM `table3` LIMIT 1);

Но у меня phpmyadmin почему-то ругается на начало второй строки, типа «неожиданный символ», хотя запрос исполняется.

usdglander

О! Спасибо огромное. 🙂 Заработало.
Хотя, я всё равно считаю MySQL какой то магией 😉

upd: У меня PhpMyAdmin не давал сохранить процедуру с таким запросом ругаясь на UNION внутри вложенного запроса. Хотя, возможно это потому что MariaDB. :\ Может такое быть?

Источник

Оцените статью