Форум программистов, компьютерный форум, киберфорум
Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/6: Рейтинг темы: голосов - 6, средняя оценка - 5.00
4 / 5 / 3
Регистрация: 03.11.2012
Сообщений: 173

JOIN-запрос, дубли

18.05.2018, 15:40. Показов 1219. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
В общем есть table1 со столбцами a, b.
И вторая таблица table2 со столбцами скажем b,d,x. (причем здесь в столбце b значения могут повторяться, но для каждого b значение d определено однозначно).
Нужно выбрать из первой таблицы стороки, для которых допустим d=1.
(здесь связь по b понятное дело: LEFT JOIN ON table1.b=table2.b)
Но если так делать, то получается дублирование строк в выходном результате.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
18.05.2018, 15:40
Ответы с готовыми решениями:

Запрос игнорирует дубли
Подскажите, плиз Этот запрос почему-то игнорирует одинаковые данные. Если есть несколько дублей, то берет только один. ...

Дубли !!! HELP !!!
Ламерская проблема - нужно удалить записи, повторяющиеся только по одному полю. Подскажите, плиз...

Удалить дубли в базе, медленный запрос
Добрый день, Подскажите как можно или оптимизировать или переписать запрос по друому? суть в том что есть 4 таблицы в базе, где каждый...

9
5962 / 4538 / 1094
Регистрация: 29.08.2013
Сообщений: 28,148
Записей в блоге: 3
18.05.2018, 15:43
а вопрос в чем?
0
4 / 5 / 3
Регистрация: 03.11.2012
Сообщений: 173
18.05.2018, 16:12  [ТС]
Цитата Сообщение от qwertehok Посмотреть сообщение
а вопрос в чем?
нужно, чтобы на выходе не было повторяющихся строк, а так они есть. Можно конечно потом удалить, но это наверное не самое рациональное решение
0
5962 / 4538 / 1094
Регистрация: 29.08.2013
Сообщений: 28,148
Записей в блоге: 3
18.05.2018, 16:22
ну так они есть не просто так
у вас в условии сказано
Цитата Сообщение от spyphy Посмотреть сообщение
причем здесь в столбце b значения могут повторяться
поэтому и дубли

можно сгруппировать, можно удалить - решение за вами
0
4 / 5 / 3
Регистрация: 03.11.2012
Сообщений: 173
18.05.2018, 16:41  [ТС]
Что-то оно не очень хочет группироваться
Code
1
1055 (42000): Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'table1.b' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by
Это если делать
... table1 LEFT JOIN table2 ON table1.b=table2.b GROUP BY table2.b
Или тут подзапрос нужно делать?
0
5962 / 4538 / 1094
Регистрация: 29.08.2013
Сообщений: 28,148
Записей в блоге: 3
18.05.2018, 17:14
я не знаю что вы захотели сделать
а что бы убрать ошибку не вижу как вы это делаете
0
4 / 5 / 3
Регистрация: 03.11.2012
Сообщений: 173
18.05.2018, 17:58  [ТС]
Цитата Сообщение от qwertehok Посмотреть сообщение
я не знаю что вы захотели сделать
да я этого и сам толком не знаю)
Вот короче, тестовые данные:
SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
CREATE TABLE t1 (a INT, b INT);
CREATE TABLE t2 (b INT, d INT, x INT);
 
INSERT INTO t1 (a, b) VALUES (1, 1);
INSERT INTO t1 (a, b) VALUES (2, 2);
INSERT INTO t1 (a, b) VALUES (3, 1);
INSERT INTO t1 (a, b) VALUES (4, 3);
INSERT INTO t1 (a, b) VALUES (5, 2);
 
INSERT INTO t2 (b, d, x) VALUES (1, 1, 0);
INSERT INTO t2 (b, d, x) VALUES (1, 1, 1);
INSERT INTO t2 (b, d, x) VALUES (2, 1, 0);
INSERT INTO t2 (b, d, x) VALUES (2, 1, 1);
INSERT INTO t2 (b, d, x) VALUES (3, 2, 0);
INSERT INTO t2 (b, d, x) VALUES (3, 2, 1);
 
SELECT t1.a, t1.b FROM t1 JOIN t2 ON t1.b = t2.b WHERE d=1;
На выходе хочу получить только 4 записи из t1, для которых d=1 (т.е. не включать случай b=3, поскольку для него d=2 согласно t2).
0
5962 / 4538 / 1094
Регистрация: 29.08.2013
Сообщений: 28,148
Записей в блоге: 3
18.05.2018, 18:21
так?
SQL
1
2
3
SELECT t1.*
FROM t1
WHERE t1.b IN (SELECT t2.b FROM t2 WHERE t2.d=1)
0
Покинул форум
3700 / 1483 / 355
Регистрация: 07.05.2015
Сообщений: 2,903
18.05.2018, 20:00
Цитата Сообщение от spyphy
На выходе хочу получить только 4 записи...
SQL
1
SELECT DISTINCT /* далее остальной запрос */
0
4 / 5 / 3
Регистрация: 03.11.2012
Сообщений: 173
18.05.2018, 22:38  [ТС]
Цитата Сообщение от qwertehok Посмотреть сообщение
так?
Да, думаю, сойдет такой вариант, спасибо
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
18.05.2018, 22:38
Помогаю со студенческими работами здесь

Запрос с INNER JOIN
Есть 2 таблички : Rabotniki и Realizaciya! Мне надо по табельному номеру найти работников и станки, которыми они занимаются ...

Запрос с Left Join
Ребят, помогите пожалуйста разобраться! Нужно запрос построить, вообще, в Access, но думаю не принципиально, лишь бы используя язык SQL. ...

Запрос по left join
Здравствуйте. Подскажите логику запроса. Имеется стандартный select A.name1, A.name2, count (B.name3) FROM TableA A LEFT JOIN...

Запрос, аналогичный cross join
Продемонстрируйте и поясните работу конструкции CROSS JOIN. SELECT * FROM Table_1 CROSS JOIN TABLE_2; Получите аналогичный...

Запрос с inner join в иерархической структуре
Есть 2 таблицы в одной хранятся название предметов и их коллекции (иерархическая структура) В другой название помещений. вот сам запрос...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь(не выше 3-го порядка) постоянного тока с элементами R, L, C, k(ключ), U, E, J. Программа находит переходные токи и напряжения на элементах схемы классическим методом(1 и 2 з-ны. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru