Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2003.05.19;
Скачать: CL | DM;

Вниз

SQL запрос: поиск двойников   Найти похожие ветки 

 
Deedlit ©   (2003-04-27 13:46) [0]

Привет всем. :)

Вопрос... есть локальная БД медицинского учреждения, хранящая список пациентов, за, скажем, последний год. Нужно отфильтровать людей, имеющих одинаковые имена, даты рождения и пол. Кто-нибудь пытался это сделать без помощи тупого перебора? Оператор ведь уснет... :( С другой стороны, я никак не могу составить SQL запрос.


 
Тих   (2003-04-27 15:03) [1]

select distinct name, sec_name, last_name, sex from [table_name]?


 
DrPass ©   (2003-04-27 16:40) [2]

В два шага: во-первых,
select name, sec_name, last_name, sex, count(*) as cnt from [table_name] group by name, sec_name, last_name, sex
во-вторых, выбираешь только те, где cnt>1


 
АлексейК   (2003-04-28 04:31) [3]

select name, sec_name, last_name, sex from [table_name]
group by name, sec_name, last_name, sex, count(name) as cnt
having count(name)>1
Таким образом можно вывести всех двойников, тройников и т.д., группируя по нескольким полям или по одному.


 
Anatoly Podgoretsky ©   (2003-04-28 11:19) [4]

DrPass © (27.04.03 16:40)
Зачем в два шага? Вот в один АлексейК (28.04.03 04:31) и соответствует SQL89 не говоря уже про SQL92


 
GLUKAS ©   (2003-04-28 14:15) [5]

Select name, sec_name, last_name, sex
from table1 t
where (select count(*) from table1 where name=t.name and sec_name=t.secname and last_name=t.lastname and sex=t.sex)>1;


Во че на вскидку получилось..... 8)



Страницы: 1 вся ветка

Текущий архив: 2003.05.19;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.013 c
14-59868
SPeller
2003-04-28 12:08
2003.05.19
Задача


3-59551
Dimaz-z
2003-04-25 21:20
2003.05.19
Как скопировать записи из одной базы данных в другую?


3-59635
Explorer
2003-04-29 07:45
2003.05.19
CheckBox в DbGridEh


8-59815
Demetrius
2003-02-04 19:28
2003.05.19
G32


14-59906
гончий
2003-04-29 10:45
2003.05.19
Нужен компонент для проигрывания mp3 файлов