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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> выборка из одной таблицы с разными параметрами 
:(
    Опции темы
Swatch
Дата 5.2.2015, 05:58 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



Подскажите, пожалуйста, есть таблица, в которой хранятся работники, выполненные ими типы заданий (для одного может быть их много), и статус по заданиям. Мне нужно написать выборку, чтобы получился список работников в первом столбце, а в остальных количество заданий по статусам. Примерно в таком виде:
  
            тип    Тип                     Всего выполнено    Заданий взятых
            задания1      задания 2             заданий                 в работу
работник 1    5      1                               2                             6
работник 2    2       2                               2                           4

Я пишу примерно так
Код

select distinct rabotnic,
(select count(1) from rabot r where r.rabotnik_id=a.rabotnik_id/*условие 1*/)
,(select count(1) from rabot r  where r.rabotnik_id=a.rabotnik_id/*условие 2*/)
,(select count(1) from rabot r where r.rabotnik_id=a.rabotnik_id/*условие 3*/)
,(select count(1) from rabot r where r.rabotnik_id=a.rabotnik_id/*условие 4*/)
from rabot a
where 
/*условие 5*/
order by rabotnic


Мне кажется, такой запрос не очень красивым и правильным, т.к. выборка из одной таблицы и условия сильно повторяются.

Есть идеи, как написать по-другому?
PM MAIL   Вверх
Akina
Дата 5.2.2015, 08:57 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


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


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

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



Почитайте про GROUP BY


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

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


Опытный
**


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

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



Попыталась сделать транспонирование. получилось красиво, но почему-то теперь по работникам не объединяется. Код такой 
Код

select rabotnic,
decode(type,'type1',ct,null)
,decode(type,'type2',ct,null)
from 
(select rabotnic, count(1) ct, type from rabot r 
where 
/*условие 1*/
group by rabotnic,type
)
group by rabotnic
order by rabotnic


Вот последний group by rabotnic почему-то не хочет работать. 

Это сообщение отредактировал(а) Swatch - 5.2.2015, 09:09
PM MAIL   Вверх
Akina
Дата 5.2.2015, 12:34 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


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


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

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



Наверное, потому, что не понимает, чего ты хочешь.
Почитай ещё и про алиасы.


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

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


Опытный
**


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

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



алиасы тут не при чем. и они, кстати, не помогли. Помог вызов max перед декодами. smile
PM MAIL   Вверх
Akina
Дата 5.2.2015, 13:12 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


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


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

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



Цитата(Swatch @  5.2.2015,  13:49 Найти цитируемый пост)
алиасы тут не при чем

Вообще-то при чём. Поле rabotnic есть как в наборе записей подзапроса, так и в таблице, являющейся его источником.

Цитата(Swatch @  5.2.2015,  13:49 Найти цитируемый пост)
Помог вызов max перед декодами.

Да вообще непонятно, как Oracle не послал тебя в syntax error с частичной группировкой. Это не MySQL, а Decode ни разу не групповая операция.


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

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


Чо?
****


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

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



Цитата(Akina @  5.2.2015,  14:12 Найти цитируемый пост)
непонятно, как Oracle не послал тебя в syntax error

От чего-ж не послал, судя по всему - послал 

Цитата(Swatch @  5.2.2015,  10:07 Найти цитируемый пост)
почему-то не хочет работать.


Цитата(Akina @  5.2.2015,  14:12 Найти цитируемый пост)
Поле rabotnic есть как в наборе записей подзапроса, так и в таблице, являющейся его источником.

У них разные зоны видимости. Извне подзапроса видно только то из него, что перечислено в его select-list. Конфликта имен тут не должно быть. Разве что внутри подзапроса, где джойн.



--------------------
Достоверно известно, что 89% людей доверяют статистике взятой с потолка smile
PM   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Oracle"
Zloxa
LSD

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

  • при создании темы давайте ей осмысленное название, описывающее суть проблемы
  • указывайте используемую версию базы, способ соединения и язык программирования
  • при ошибках обязательно приводите код ошибки и сообщение сервера
  • приводите код в котором возникла ошибка, по возможности дайте тестовый пример демонстрирующий ошибку
  • при вставке кода используйте соответсвующие теги: [code=sql] [/code] для подсветки SQL и PL/SQL кода, [code=java] [/code] - для Java, и т.д.

  • документация по Oracle: 9i, 10g, 11g
  • книги по Oracle можно поискать здесь
  • действия модераторов можно обсудить здесь

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

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


 




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


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

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