Помогите с SQL запросом - union и удаление дубликатов

программирование базы данных sql access

Доброго времени суток!
Прошу помощи с такой задачей:

Есть таблица:

Ключ Имя Состояние Дата
1 имя1 1 .....
2 имя2 1 .....
3 имя1 2 .....
3 имя3 1 .....

Нужно вывести все имена с таким условием: если у Имени есть запись с состоянием 1 и 2, вывести запись с состоянием 2, если нет такой записи, вывести то, что есть.

Т.е. результат должен быть такой:


Ключ Имя Состояние Дата
2 имя2 1 .....
3 имя1 2 .....
3 имя3 1 .....

Пишу запрос:

select * from table where Состояние=2

union

select * from table where Состояние=1

Теоретически, union должен отсекать повторяющееся имя "Имя1", но в результате запроса я получаю исходную таблицу.

Все работает, если я пишу так:
select Имя, Дата from table where Состояние=2

union

select Имя, Дата from table where Состояние=1
Но в таком случае я не вижу состояние, а оно нужно.


Вопрос - как получить желаемый результат?
Спасибо!

п.с.
Запрос вида

select distinct * from
(select * from table where Состояние=2

union

select * from table where Состояние=1)

дает тоже неверный результат.

Может быть у меня изначально неправильный подход?

Ответы:
select * from (select * from table where состояние=1 and состояние=2) where состояние=2
union
select * from table where состояние=1 and состояние<>2 or состояние=2 and состояние<>1
> Теоретически, union должен отсекать повторяющееся имя "Имя1"
union будет отсекать только абсолютно одинаковые строки, а так как состояния разные, этого не произойдет


12 лет назад

RPI.su - самая большая русскоязычная база вопросов и ответов. Наш проект был реализован как продолжение популярного сервиса otvety.google.ru, который был закрыт и удален 30 апреля 2015 года. Мы решили воскресить полезный сервис Ответы Гугл, чтобы любой человек смог публично узнать ответ на свой вопрос у интернет сообщества.

Все вопросы, добавленные на сайт ответов Google, мы скопировали и сохранили здесь. Имена старых пользователей также отображены в том виде, в котором они существовали ранее. Только нужно заново пройти регистрацию, чтобы иметь возможность задавать вопросы, или отвечать другим.

Чтобы связаться с нами по любому вопросу О САЙТЕ (реклама, сотрудничество, отзыв о сервисе), пишите на почту [email protected]. Только все общие вопросы размещайте на сайте, на них ответ по почте не предоставляется.