Форум: "Базы";
Текущий архив: 2003.05.19;
Скачать: [xml.tar.bz2];
Вниз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;
Скачать: [xml.tar.bz2];
Память: 0.45 MB
Время: 0.007 c