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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> помогите дополнить запрос 
:(
    Опции темы
Sharkfire88
Дата 31.1.2011, 12:51 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Есть 3 таблицы (СУБД Firebird)

Код

CREATE TABLE TASKS (
    ID_TASK      TYPE_ID,
    ID_OWNER     TYPE_ID,
    ID_USER      TYPE_ID,
);

CREATE TABLE PROJECT_CONTENT (
    ID_ITEM     TYPE_ID,
    ID_PROJECT  TYPE_ID,
    TYPE_ITEM   TYPE_SMALLINT DEFAULT 0
);

CREATE TABLE PROJECTS (
    ID_PROJECT    TYPE_ID,
    ID_OWNER      TYPE_ID,
    ID_SHARE      TYPE_ID DEFAULT -1,
 );


Первая таблица - справочник заданий, вторая это служебная таблица, в которой указано к какому проекту привязано задание (или не задание а другой объект), 3ия таблица - справочник проектов.

В справочнике проектов есть поле id_share - оно указывает, кому кроме id_owner можно показывать содержимое проекта.

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

Код

select t.id_task
from 
tasks t join project_content pc on t.id_task = pc.id_item and pc.type_item=0 (0 - поручения)
join projects p on pc.id_project = p.id_project and p.id_share = 2


теперь мне желательно в этом же запросе вывести список поручений, которые просто принадлежат юзеру исходя из tasks.id_owner

как бы я не дополнял этот запрос у меня получается декартово произведение таблиц! помоги пожалуйста!

Это сообщение отредактировал(а) Sharkfire88 - 31.1.2011, 13:11
PM MAIL   Вверх
Akina
Дата 31.1.2011, 14:03 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


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


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

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



Получи свой список поручений отдельным запросом и сделай UNION ALL с этим запросом.


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

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


Новичок



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

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



К сожалению не могу выполнять 2 запроса. Точнее очень хочу обойтись без этого. 

я понимаю что где то надо вставить where id_owner = 2 но где ? ... 
PM MAIL   Вверх
Akina
Дата 1.2.2011, 08:49 (ссылка) |    (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


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


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

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



Цитата(Sharkfire88 @  1.2.2011,  00:59 Найти цитируемый пост)
не могу выполнять 2 запроса

Так это же будет один запрос...


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

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


Чо?
****


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

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



Код

select t.id_task
from 
tasks t 
left join project_content pc on t.id_task = pc.id_item and pc.type_item=0 --(0 - поручения)
left join projects p on pc.id_project = p.id_project and p.id_share = 2
where p.id_project is not null and pc.id_item is not null
  or  id_owner = 2



--------------------
Достоверно известно, что 89% людей доверяют статистике взятой с потолка smile
PM   Вверх
Sharkfire88
Дата 1.2.2011, 11:48 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Спасибо! Вот это оно!

Правда у меня в плане запроса :

PLAN JOIN (SORT (JOIN (T NATURAL, PC INDEX (PROJECT_C_IDX1))), P INDEX (PROJECTS_IDX1))

но таблица не больше 1000 записей будет. думаю не страшно 

Это сообщение отредактировал(а) Sharkfire88 - 1.2.2011, 12:35
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Составление SQL-запросов | Следующая тема »


 




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


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

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