Sql server: union all operator

Советы и хитрости программирования

Хотя согласно стандарту ANSI оператор INTERSECT имеет более высокий приоритет по сравнению с другими операторами для работы с наборами, на многих платформах эти операторы рассматриваются как имеющие одинаковый приоритет. Вы можете явным образом управлять приоритетом операторов, используя скобки. В противном случае СУБД, скорее всего, будет выполнять их в порядке слева направо.

Предложение DISTINCT может (в зависимости от платформы) потребовать существенных затрат производительности, поскольку при этом часто требуется дополнительный проход по результирующему набору для удаления дублирующихся записей. Предложение ALL для увеличения производительности можно указывать во всех случаях, когда не ожидается наличия дубликатов (или если дубликаты допустимы).

Согласно стандарту ANSI в запросе можно использовать только одно предложение ORDER BY. Ставьте его в конце последней инструкции SELECT. Чтобы избежать двусмысленности при указании столбцов и таблиц, обязательно присваивайте всем столбцам всех таблиц соответствующие псевдонимы. Тем не менее при указании имен столбцов в запросе SELECT … UNION используется только псевдоним из первого запроса. Например:

SELECT
 au_lname AS lastname,
 au_fname AS firstname
FROM authors
UNION
SELECT
 emp_lname AS lastname,
 emp_fname AS firstname
FROM employees
ORDER BY lastname, firstname;

Кроме того, поскольку в запросах оператора UNION могут содержаться столбцы с совместимыми типами данных, возможны вариации поведения кода на разных платформах, особенно в том, что касается длины типа данных столбца. Например, если столбец au_fname первого запроса заметно длиннее столбца emplname второго запроса, то разные платформы могут применять разные правила определения используемой длины. Однако, как правило, платформы выбирают для результирующего набора более длинный (и менее ограниченный) тип данных.

Каждая СУРБД может применять свои собственные правила определения имени столбца, если столбцы в разных таблицах имеют разные имена. Как правило, используются имена из первого запроса.

UNION

Последнее обновление: 20.07.2017

Оператор UNION подобно inner join или outer join позволяет соединить две таблицы. Но в отличие от inner/outer join
объединения соединяют не столбцы разных таблиц, а два однотипных набора в один. Формальный синтаксис объединения:

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

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

USE usersdb;

CREATE TABLE Customers
(
    Id INT IDENTITY PRIMARY KEY,
    FirstName NVARCHAR(20) NOT NULL,
	LastName NVARCHAR(20) NOT NULL,
	AccountSum MONEY
);
CREATE TABLE Employees
(
    Id INT IDENTITY PRIMARY KEY,
    FirstName NVARCHAR(20) NOT NULL,
	LastName NVARCHAR(20) NOT NULL,
);

INSERT INTO Customers VALUES
('Tom', 'Smith', 2000),
('Sam', 'Brown', 3000),
('Mark', 'Adams', 2500),
('Paul', 'Ins', 4200),
('John', 'Smith', 2800),
('Tim', 'Cook', 2800)

INSERT INTO Employees VALUES
('Homer', 'Simpson'),
('Tom', 'Smith'),
('Mark', 'Adams'),
('Nick', 'Svensson')

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

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

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

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

SELECT FirstName + ' ' +LastName AS FullName
FROM Customers
UNION SELECT FirstName + ' ' + LastName AS EmployeeName 
FROM Employees
ORDER BY FullName DESC

В данном случае каждая выборка имеет по одному столбцу, который представляет объединение имени и фамилии клиента или сотрудника.
Но в случае с клиентами столбец будет называться FullName, а в случае с сотрудниками — EmployeeName. Тем не менее для сортировки применяется название столбца из первой выборки и он же будет в результирующей выборке:

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

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

Также соответствующие столбцы должны соответствовать по типу. Так, следующий пример завершится с ошибкой из-за не соответствия по типу данных:

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

В данном случае первый столбец первой выборки имеет тип NVARCHAR, то есть хранит строку. Первый столбец второй выборки — Id имеет тип INT, то есть хранит число.

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

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

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

SELECT FirstName, LastName, AccountSum + AccountSum * 0.1 AS TotalSum 
FROM Customers WHERE AccountSum = 3000

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

НазадВперед

Пример с использованием ORDER BY

MySQL оператор UNION ALL может использовать ORDER BY, для сортировки результирующего набора. Например:

MySQL

SELECT supplier_id, supplier_name
FROM suppliers
WHERE state = ‘California’
UNION ALL
SELECT company_id, company_name
FROM companies
WHERE company_id > 3000
ORDER BY 2;

1
2
3
4
5
6
7
8

SELECTsupplier_id,supplier_name

FROMsuppliers

WHEREstate=’California’

UNION ALL

SELECTcompany_id,company_name

FROMcompanies

WHEREcompany_id>3000

ORDER BY2;

Поскольку имена столбцов различаются между двумя предложениями SELECT, то в MySQL операторе UNION ALL более выгодно ссылаться на столбцы в предложении ORDER BY по их позиции в результирующем наборе. В этом примере мы отсортировали результаты по supplier_name / company_name в порядке возрастания, как обозначено ORDER BY 2.

Поля supplier_name / company_name находятся позиции № 2 в результирующем наборе.

Example — Single Field With Same Name

Let’s look at how to use the SQL UNION ALL operator that returns one field. In this simple example, the field in both SELECT statements will have the same name and data type.

For example:

SELECT supplier_id
FROM suppliers
UNION ALL
SELECT supplier_id
FROM orders
ORDER BY supplier_id;

This SQL UNION ALL example would return the supplier_id multiple times in the result set if that same value appeared in both the suppliers and orders table. The SQL UNION ALL operator does not remove duplicates. If you wish to remove duplicates, try using the UNION operator.

Now, let’s explore this example further will some data.

If you had the suppliers table populated with the following records:

supplier_id supplier_name
1000 Microsoft
2000 Oracle
3000 Apple
4000 Samsung

And the orders table populated with the following records:

order_id order_date supplier_id
1 2015-08-01 2000
2 2015-08-01 6000
3 2015-08-02 7000
4 2015-08-03 8000

And you executed the following UNION ALL statement:

SELECT supplier_id
FROM suppliers
UNION ALL
SELECT supplier_id
FROM orders
ORDER BY supplier_id;

You would get the following results:

supplier_id
1000
2000
2000
3000
4000
6000
7000
8000

Правила использования

Существуют два основных правила, регламентирующие порядок использования оператора :

  • число и порядок извлекаемых столбцов должны совпадать во всех объединяемых запросах;
  • типы данных в соответствующих столбцах должны быть совместимы.

Типы данных столбцов, данные из которых извлекаются в объединяемых запросах, не обязательно должны полностью совпадать, однако должны быть совместимыми путём неявного преобразования. Если типы данных различаются, то получившийся тип данных определяется на основе правил очередности типов данных (для конкретной СУБД). Если типы совпадают, но различаются в точности, масштабе или длине, результат определяется на основе правил, используемых для объединения выражений (для конкретной СУБД). Типы не определенные ANSI, такие как DATA и BINARY, обычно должны совпадать с другими столбцами такого же нестандартного типа.

В Microsoft SQL Server столбцы с типом данных XML должны быть эквивалентными. Все столбцы должны либо иметь тип, определенный в XML-схеме, либо быть нетипизированными. Типизированные столбцы должны относиться к одной и той же коллекции XML-схем.

Ещё одно ограничение на совместимость — это запрет пустых значений (NULL) в любом столбце объединения, причем эти значения необходимо запретить и для всех соответствующих столбцов в других запросах объединения, поскольку пустые значения (NULL) запрещены с ограничением NOT NULL. Кроме того, нельзя использовать UNION в подзапросах, а также нельзя использовать агрегатные функции в предложении SELECT запроса в объединении (однако большинство СУБД пренебрегают этими ограничениями).

Демонстрационная база данных

В этом учебнике мы будем использовать хорошо известную базу данных Northwind Sample.

Ниже представлен выбор из таблицы «Customers»:

CustomerID CustomerName ContactName Address City PostalCode Country
1 Alfreds Futterkiste Maria Anders Obere Str. 57 Berlin 12209 Germany
2 Ana Trujillo Emparedados y helados Ana Trujillo Avda. de la Constitución 2222 México D.F. 05021 Mexico
3 Antonio Moreno Taquería Antonio Moreno Mataderos 2312 México D.F. 05023 Mexico

И выбор из таблицы «Поставщики»:

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

Синтаксис

Синтаксис для оператора UNION в MySQL:

SELECT expression1, expression2, … expression_n FROM tables UNION SELECT expression1, expression2, … expression_n FROM tables ;

Параметры или аргументы

expression1, expression2, … expression_n — столбцы или вычисления, которые вы хотите получить.tables — таблицы, из которых вы хотите получить записи. Должна быть хотя бы одна таблица, перечисленная в операторе FROM.WHERE conditions — необязательный. Условия, которые должны быть выполнены для выбранных записей.DISTINCT — необязательный. Удаляет дубликаты из результирующего набора, но включение модификатора DISTINCT не влияет на результирующий набор оператора UNION, потому что по умолчанию оператор UNION уже удаляет дубликаты.

SQL Server UNION examples

See the following and tables from the sample database:

and examples

The following example combines names of staffs and customers into a single list:

1
2
3
4
5
6
7
8
9
10
11

SELECT

first_name,

last_name

FROM

sales.staffs

UNION
SELECT

first_name,

last_name

FROM

sales.customers;

It returns 1,454 rows.

The  table has 10 rows and the customers table has 1,445 rows as shown in the following queries:

1
2
3
4
5
6
7
8
9
10
11

SELECT

COUNT (*)

FROM

sales.staffs;

— 10      
 
SELECT

COUNT (*)

FROM

sales.customers;

— 1454

Because the result set of the union returns only 1,454 rows, it means that one duplicate row was removed.

To include the duplicate row, you use the as shown in the following query:

1
2
3
4
5
6
7
8
9
10
11

SELECT

first_name,

last_name

FROM

sales.staffs

UNIONALL

SELECT

first_name,

last_name

FROM

sales.customers;

The query returns 1,455 rows as expected.

and example

To sort the result set returned by the  operator, you place the clause in the last query as follows:

1
2
3
4
5
6
7
8
9
10
11

SELECT

select_list

FROM

table_1

UNION
SELECT

select_list

FROM

table_2

ORDERBY

order_list;

For example, to sort the first names and last names of customers and staffs, you use the following query:

1
2
3
4
5
6
7
8
9
10
11
12
13
14

SELECT

first_name,

last_name

FROM

sales.staffs

UNIONALL

SELECT

first_name,

last_name

FROM

sales.customers

ORDERBY

first_name,

last_name;

In this tutorial, you have learned how to use the SQL Server to combines rows from multiple queries into a single result set.

  • Was this tutorial helpful ?

SQL References

SQL Keywords
ADD
ADD CONSTRAINT
ALTER
ALTER COLUMN
ALTER TABLE
ALL
AND
ANY
AS
ASC
BACKUP DATABASE
BETWEEN
CASE
CHECK
COLUMN
CONSTRAINT
CREATE
CREATE DATABASE
CREATE INDEX
CREATE OR REPLACE VIEW
CREATE TABLE
CREATE PROCEDURE
CREATE UNIQUE INDEX
CREATE VIEW
DATABASE
DEFAULT
DELETE
DESC
DISTINCT
DROP
DROP COLUMN
DROP CONSTRAINT
DROP DATABASE
DROP DEFAULT
DROP INDEX
DROP TABLE
DROP VIEW
EXEC
EXISTS
FOREIGN KEY
FROM
FULL OUTER JOIN
GROUP BY
HAVING
IN
INDEX
INNER JOIN
INSERT INTO
INSERT INTO SELECT
IS NULL
IS NOT NULL
JOIN
LEFT JOIN
LIKE
LIMIT
NOT
NOT NULL
OR
ORDER BY
OUTER JOIN
PRIMARY KEY
PROCEDURE
RIGHT JOIN
ROWNUM
SELECT
SELECT DISTINCT
SELECT INTO
SELECT TOP
SET
TABLE
TOP
TRUNCATE TABLE
UNION
UNION ALL
UNIQUE
UPDATE
VALUES
VIEW
WHERE

MySQL Functions
String Functions
ASCII
CHAR_LENGTH
CHARACTER_LENGTH
CONCAT
CONCAT_WS
FIELD
FIND_IN_SET
FORMAT
INSERT
INSTR
LCASE
LEFT
LENGTH
LOCATE
LOWER
LPAD
LTRIM
MID
POSITION
REPEAT
REPLACE
REVERSE
RIGHT
RPAD
RTRIM
SPACE
STRCMP
SUBSTR
SUBSTRING
SUBSTRING_INDEX
TRIM
UCASE
UPPER

Numeric Functions
ABS
ACOS
ASIN
ATAN
ATAN2
AVG
CEIL
CEILING
COS
COT
COUNT
DEGREES
DIV
EXP
FLOOR
GREATEST
LEAST
LN
LOG
LOG10
LOG2
MAX
MIN
MOD
PI
POW
POWER
RADIANS
RAND
ROUND
SIGN
SIN
SQRT
SUM
TAN
TRUNCATE

Date Functions
ADDDATE
ADDTIME
CURDATE
CURRENT_DATE
CURRENT_TIME
CURRENT_TIMESTAMP
CURTIME
DATE
DATEDIFF
DATE_ADD
DATE_FORMAT
DATE_SUB
DAY
DAYNAME
DAYOFMONTH
DAYOFWEEK
DAYOFYEAR
EXTRACT
FROM_DAYS
HOUR
LAST_DAY
LOCALTIME
LOCALTIMESTAMP
MAKEDATE
MAKETIME
MICROSECOND
MINUTE
MONTH
MONTHNAME
NOW
PERIOD_ADD
PERIOD_DIFF
QUARTER
SECOND
SEC_TO_TIME
STR_TO_DATE
SUBDATE
SUBTIME
SYSDATE
TIME
TIME_FORMAT
TIME_TO_SEC
TIMEDIFF
TIMESTAMP
TO_DAYS
WEEK
WEEKDAY
WEEKOFYEAR
YEAR
YEARWEEK

Advanced Functions
BIN
BINARY
CASE
CAST
COALESCE
CONNECTION_ID
CONV
CONVERT
CURRENT_USER
DATABASE
IF
IFNULL
ISNULL
LAST_INSERT_ID
NULLIF
SESSION_USER
SYSTEM_USER
USER
VERSION

SQL Server Functions
String Functions
ASCII
CHAR
CHARINDEX
CONCAT
Concat with +
CONCAT_WS
DATALENGTH
DIFFERENCE
FORMAT
LEFT
LEN
LOWER
LTRIM
NCHAR
PATINDEX
QUOTENAME
REPLACE
REPLICATE
REVERSE
RIGHT
RTRIM
SOUNDEX
SPACE
STR
STUFF
SUBSTRING
TRANSLATE
TRIM
UNICODE
UPPER

Numeric Functions
ABS
ACOS
ASIN
ATAN
ATN2
AVG
CEILING
COUNT
COS
COT
DEGREES
EXP
FLOOR
LOG
LOG10
MAX
MIN
PI
POWER
RADIANS
RAND
ROUND
SIGN
SIN
SQRT
SQUARE
SUM
TAN

Date Functions
CURRENT_TIMESTAMP
DATEADD
DATEDIFF
DATEFROMPARTS
DATENAME
DATEPART
DAY
GETDATE
GETUTCDATE
ISDATE
MONTH
SYSDATETIME
YEAR

Advanced Functions
CAST
COALESCE
CONVERT
CURRENT_USER
IIF
ISNULL
ISNUMERIC
NULLIF
SESSION_USER
SESSIONPROPERTY
SYSTEM_USER
USER_NAME

MS Access Functions
String Functions
Asc
Chr
Concat with &
CurDir
Format
InStr
InstrRev
LCase
Left
Len
LTrim
Mid
Replace
Right
RTrim
Space
Split
Str
StrComp
StrConv
StrReverse
Trim
UCase

Numeric Functions
Abs
Atn
Avg
Cos
Count
Exp
Fix
Format
Int
Max
Min
Randomize
Rnd
Round
Sgn
Sqr
Sum
Val

Date Functions
Date
DateAdd
DateDiff
DatePart
DateSerial
DateValue
Day
Format
Hour
Minute
Month
MonthName
Now
Second
Time
TimeSerial
TimeValue
Weekday
WeekdayName
Year

Other Functions
CurrentUser
Environ
IsDate
IsNull
IsNumeric

SQL OperatorsSQL Data TypesSQL Quick Ref

What are the EU measures?

The travel ban will affect all non-EU nationals from visiting the bloc, except long-term residents, family members of EU nationals and diplomats, cross-border and healthcare workers, and people transporting goods.

Free travel is a cherished principle within the European border-free Schengen area. But in recent days many countries have unilaterally imposed full or partial border shutdowns in a bid to stop the spread of the coronavirus.

This prompted the commission to propose that the bloc act in a more unified fashion and restrict entry to the union as a whole, at the urging of French President Emmanuel Macron.

  • A visual guide to the pandemic
  • Britons urged to avoid non-essential travel abroad

The measures were agreed in a video-summit between EU leaders on Tuesday afternoon and will now have to be implemented by member states.

«They said they will immediately do that,» said EU Commission chief Ursula von der Leyen at a press conference. «This is good, so that we have a unanimous and united approach the external borders are concerned.»

The UK and the Republic of Ireland — which is part of the EU but not Schengen — will be invited to join the measure.

It was also crucial that the EU «unblocks the situation» with regards to closed internal borders, Mrs Von der Leyen said, because «too many people are stranded».

  • LIVE UPDATES: Follow the latest developments here
  • EASY STEPS: How to keep safe
  • A SIMPLE GUIDE: What are the symptoms?
  • NEW MEASURES: What is the UK advice?
  • TRAVEL PLANS: What are your rights?

Пример — разные имена полей

Нет необходимости, чтобы соответствующие столбцы в каждом операторе SELECT имели одинаковые имена, но они должны быть с одинаковыми соответствующими типами данных. Если у вас нет одинаковых имен столбцов в операторах SELECT, это становится немного сложнее, особенно если вы хотите упорядочить результаты запроса, используя оператор ORDER BY. Давайте посмотрим, как использовать оператор UNION ALL с разными именами столбцов, и упорядочить результаты запроса. Например.

PgSQL

SELECT supplier_id,
supplier_name
FROM suppliers
WHERE supplier_id > 2000
UNION ALL
SELECT company_id, company_name
FROM companies
WHERE company_id > 1000
ORDER BY 1;

1
2
3
4
5
6
7
8
9

SELECTsupplier_id,

supplier_name

FROMsuppliers

WHEREsupplier_id>2000

UNIONALL

SELECTcompany_id,company_name

FROMcompanies

WHEREcompany_id>1000

ORDERBY1;

В этом SQL примере UNION ALL, поскольку имена столбцов в двух операторах SELECT различаются, более выгодно ссылаться на столбцы в предложении ORDER BY по их положению в наборе результатов. В этом примере мы отсортировали результаты по supplier_id / company_id в порядке возрастания, как обозначено . Поля supplier_id / company_id находятся в позиции № 1 в наборе результатов. Теперь давайте рассмотрим этот пример подробнее с данными. Если у вас была таблица suppliers, заполненная следующими записями.

supplier_id supplier_name
1000 Microsoft
2000 Oracle
3000 Apple
4000 Samsung

И таблица companies заполнилась следующими записями.

company_id company_name
1000 Microsoft
3000 Apple
7000 Sony
8000 IBM

И вы выполнили следующий запрос содержащий UNION ALL.

PgSQL

SELECT supplier_id,
supplier_name
FROM suppliers
WHERE supplier_id > 2000
UNION ALL
SELECT company_id, company_name
FROM companies
WHERE company_id > 1000
ORDER BY 1;

1
2
3
4
5
6
7
8
9

SELECTsupplier_id,

supplier_name

FROMsuppliers

WHEREsupplier_id>2000

UNIONALL

SELECTcompany_id,company_name

FROMcompanies

WHEREcompany_id>1000

ORDERBY1;

Вы получите следующие результаты.

supplier_id supplier_name
3000 Apple
3000 Apple
4000 Samsung
7000 Sony
8000 IBM

Во-первых, обратите внимание, что запись с supplier_id, равной 3000, появляется дважды в наборе результатов, поскольку запрос UNION ALL возвращает все строки и не удаляет дубликаты. Во-вторых, обратите внимание, что заголовки столбцов в наборе результатов называются supplier_id и supplier_name

Это потому, что это были имена столбцов, использованных в первом операторе SELECT в UNION ALL. Если бы вы хотели, вы могли бы присвоить псевдонимы следующим образом.

PgSQL

SELECT supplier_id AS ID_Value,
supplier_name AS Name_Value
FROM suppliers
WHERE supplier_id > 2000
UNION ALL
SELECT company_id AS ID_Value, company_name AS Name_Value
FROM companies
WHERE company_id > 1000
ORDER BY 1;

1
2
3
4
5
6
7
8
9

SELECTsupplier_idASID_Value,

supplier_nameASName_Value

FROMsuppliers

WHEREsupplier_id>2000

UNIONALL

SELECTcompany_idASID_Value,company_nameASName_Value

FROMcompanies

WHEREcompany_id>1000

ORDERBY1;

Теперь заголовки столбцов в результате будут иметь псевдоним как ID_Value для первого столбца и Name_Value для второго столбца.

ID_Value Name_Value
3000 Apple
3000 Apple
4000 Samsung
7000 Sony
8000 IBM

Часто задаваемые вопросы

Вопрос: Мне нужно сравнить две даты и вернуть количество строк поля, основанного на значении дат. Например, у меня есть в таблице поле даты, которое называется дата последнего обновления. Я должен проверить, если TRUNC (last_updated_date)> = TRUNC (Sysdate-13).

Ответ: Поскольку вы используете функцию COUNT, которая является агрегатной функцией, то мы рекомендуем использовать Oracle оператор UNION. Например, вы можете попробовать следующее:

Oracle PL/SQL

SELECT a.code AS Code, a.name AS Name, COUNT(b.Ncode)
FROM cdmaster a, nmmaster b
WHERE a.code = b.code
AND a.status = 1
AND b.status = 1
AND b.Ncode ‘a10’
AND TRUNC(last_updated_date) ‘a10’
AND TRUNC(last_updated_date) > TRUNC(sysdate-13)
GROUP BY a.code, a.name;

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17

SELECTa.codeASCode,a.nameASName,COUNT(b.Ncode)

FROMcdmastera,nmmasterb

WHEREa.code=b.code

ANDa.status=1

ANDb.status=1

ANDb.Ncode>’a10′

ANDTRUNC(last_updated_date)=TRUNC(sysdate-13)

GROUPBYa.code,a.name
UNION

SELECTa.codeASCode,a.nameASName,COUNT(b.Ncode)

FROMcdmastera,nmmasterb

WHEREa.code=b.code

ANDa.status=1

ANDb.status=1

ANDb.Ncode>’a10′

ANDTRUNC(last_updated_date)>TRUNC(sysdate-13)

GROUPBYa.code,a.name;

Oracle оператор UNION позволит выполнить подсчет на основе одного набора критериев.

TRUNC(last_updated_date)

А также выполнить подсчет на основе другого набора критериев.

TRUNC(last_updated_date) > TRUNC(sysdate-13)

Membership levels

Unite membership since 2007

250,000

500,000

750,000

1,000,000

1,250,000

1,500,000

2007

2010

2013

2015

2017

A private presentation given by Unite’s former joint general secretary Tony Woodley showed that membership of the union had stood at 1.44 million in 2007 but declined by 262,740 between 2007 and 2010. During 2012, despite wider falling trade union membership and the tough economic climate, Unite increased its membership by more than 50,000 members. The union claimed 1.5 million members in January 2013, and was claiming 1.42 million by April 2017.

Unite represents many BAE Systems employees.

Demo Database

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

Below is a selection from the «Customers» table:

CustomerID CustomerName ContactName Address City PostalCode Country
1 Alfreds Futterkiste Maria Anders Obere Str. 57 Berlin 12209 Germany
2 Ana Trujillo Emparedados y helados Ana Trujillo Avda. de la Constitución 2222 México D.F. 05021 Mexico
3 Antonio Moreno Taquería Antonio Moreno Mataderos 2312 México D.F. 05023 Mexico

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

Political views

Criticism of UK government austerity measures

In June 2011, Unite publicly criticised the serving coalition government for a number of cuts in public services which caused a result of the reduction of public funding, in particular cuts to the National Health Service (NHS). Ron Singer, a retired GP of 30 years and Unite member, claimed that there were «serious concerns» over the future of the NHS.

In February 2013, Unite was among other organisations and individuals who gave their support to the People’s Assembly in a letter published by The Guardian newspaper. Representing Unite, Len McCluskey also gave a speech at the People’s Assembly Conference held at Westminster Central Hall on 22 June 2013, at which many Unite delegates and representatives were in attendance.

Threat to split from Labour and launch a new workers’ party

In April 2014, McCluskey threatened to disaffiliate Unite from Labour and launch a new workers’ party if Labour lost the 2015 General Election. Labour subsequently lost the election.

In July 2015, Unite endorsed Jeremy Corbyn’s campaign in the Labour Party leadership election.

Criticism of Israel

In July 2014, Unite described Israel as «an apartheid state» and called for «sanctions against Israel for its continued illegal occupation, flouting of international law, and construction of an apartheid regime.»

Abortion

Unite supports Abortion Rights which campaigns «to defend and extend women’s rights and access to safe, legal abortion»; among its statements it opposes the criminalisaton of sex-selective abortion.

Ссылка на основную публикацию