Модераторы: LSD
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Вопрос по left join 
V
    Опции темы
yezh
Дата 6.2.2008, 14:57 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 95
Регистрация: 18.12.2005
Где: Москва

Репутация: нет
Всего: нет



Нужно присоединить таблицу слева. Но при этом на нее накладываются некоторые условия. Примерно так:
выбираем все записи из t1. Присоединяем слева таблицу t2. При этом должны выполниться условия что t2.p1 = t3.p2, t3.p2=10, t3 и t1 никак не связаны. соответственно услвие для связи t1 и t2 есть.
Как мне в left join приписать еще одну таблицу? 
пробовал такой код:
Код

select t1.p1, t1.p2 ... t1.p10, t2.p1 
from t1 left join t2, t3 on t1.p1 = t2.p5 and t2.p1=t3.p2 and t3.p1 = 10 
where ...

Не работает  smile 
Может подскажете как сделать?
PM MAIL ICQ   Вверх
geckelberryfinn
Дата 6.2.2008, 15:27 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 65
Регистрация: 3.12.2003

Репутация: нет
Всего: нет



а нельзя вот так
Код

select t1.p1, t1.p2 ... t1.p10, t2.p1 
from (t1 left join t2 on  t1.p1 = t2.p5) inner join t3 on t2.p1=t3.p2 and t3.p1 = 10 
where ...


Возможно придется привести к типу - таблица... щас уже точно не соображу, но логика такая


PM MAIL   Вверх
yezh
Дата 6.2.2008, 15:40 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 95
Регистрация: 18.12.2005
Где: Москва

Репутация: нет
Всего: нет



Хмм... ошибок не выдает но работает как то странно. Лан, может условия не те, это уже потом буду смотреть... а если добавить еще одну таблицу, которая тоже будет связываться с t2? А-ля:
Код

 t2.p1 = t3.p2, t3.p2=10, t4.p1 = t2.p3

и при этом t2,t3 и t1 между собой никак не связаны?

Добавлено через 54 секунды
Просто добавляется еще один INNER JOIN?
PM MAIL ICQ   Вверх
Akina
Дата 6.2.2008, 15:42 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Советчик
****


Профиль
Группа: Модератор
Сообщений: 20581
Регистрация: 8.4.2004
Где: Зеленоград

Репутация: 13
Всего: 454



t3.p1 = 10 - явно для секции WHERE

Добавлено через 1 минуту и 39 секунд
а вообще 

Код

from t1 left join (t2 join t3 on t2.p1=t3.p2 and t3.p1 = 10) on t1.p1 = t2.p5 




--------------------
 О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума.

PM MAIL WWW ICQ Jabber   Вверх
yezh
Дата 6.2.2008, 15:57 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 95
Регистрация: 18.12.2005
Где: Москва

Репутация: нет
Всего: нет



Спасиб, разобрался. Второй вариант заработал нормально вроде бы...
PM MAIL ICQ   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Общие вопросы по базам данных"
LSD
Zloxa

Данный форум предназначен для обсуждения вопросов о базах данных не попадающих под тематику других форумов:

  • вопросам по СУБД для которых нет отдельных подфорумов
  • вопросам которые затрагивают несколько разных СУБД (например проблема выбора)
  • инструменты для работы с СУБД
  • вопросы проектирования БД
  • теоретически вопросы о СУБД

Данный форум не предназначен для:

  • вопросов о поиске разлиных БД (если не понимаете чем БД отличается от СУБД то: а) вам не сюда; б) Google в помощь)
  • обсуждения проблем с доступом к СУБД из различных ЯП (для этого есть соответсвующие форумы по каждому ЯП)
  • обсуждения проблем с написание SQL запросов, для этого есть форум Составление SQL-запросов
  • просьб о написании курсовой, реферата и т.п., для этого есть Центр помощи или фриланс биржа
  • объявлений о найме специалистов, для этого есть раздел Объявления о найме специалистов

Если вы не соблюдаете эти правила, не удивляйтесь потом не найдя свою тему/сообщение. ;)


Полезные советы:

При написании сообщения постарайтесь дать теме максимально понятное название. В теме максимально подробно опишите проблему. Если применимо укажите: название базы данных и версии (MySQL 4.1, MS SQL Server 2000 и т.п.); используемых язык программирования; способа доступа (ADO, BDE и т.д.); сообщения об ошибках.

Для вставки кода используйте теги [code=sql] [/code].

Литературу по базам данных можно поискать здесь.

Действия модераторов можно обсудить здесь.


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, LSD, Zloxa.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | СУБД, общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.0623 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.