Главная страница
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.016 c
1-59703
Суперчайник
2003-05-08 01:51
2003.05.19
Проблема со строками


14-59864
Slavik
2003-04-29 01:12
2003.05.19
Transfer of application from Delphi 5 to Delphi 7


1-59784
oleg_sys
2003-05-06 21:51
2003.05.19
Вывод графики в файл


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


14-59923
stas_a
2003-04-30 09:50
2003.05.19
Функции чужой Dll