crossplatform.ru

Здравствуйте, гость ( Вход | Регистрация )

> Непонятная работа UNION
NetWorm
  опции профиля:
сообщение 12.11.2011, 20:53
Сообщение #1


Студент
*

Группа: Участник
Сообщений: 24
Регистрация: 2.8.2011
Пользователь №: 2784

Спасибо сказали: 0 раз(а)




Репутация:   0  


SELECT
   materials.name AS material,
   SUM(o_sklad.count) AS count,
   ed_izm.name AS ed_izm,
   0 AS count2
FROM
   o_sklad,
   materials,
   ed_izm
WHERE
   o_sklad.id_material = materials.id
   AND materials.id_ed_izm = ed_izm.id
   AND o_sklad.date <'01.11.2011'
GROUP BY
   materials.name,
   ed_izm.name

   UNION ALL

SELECT
   materials.name AS material,
   SUM(0) AS count,
   ed_izm.name AS ed_izm,
   SUM(o_sklad.count) AS count2
FROM
   o_sklad,
   materials,
   ed_izm
WHERE
   o_sklad.id_material = materials.id
   AND materials.id_ed_izm = ed_izm.id
   AND o_sklad.date <'30.11.2011'
GROUP BY
   materials.name,
   ed_izm.name


И в результате возвращаются двойные строки. т.е. он не объединяет SUM(0) AS count2 из первого запроса и SUM(o_sklad.count) AS count2. Короче мне нужно получить одну таблицу с результатами двух запросов
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
 
Начать новую тему
Ответов
ilyabvt
  опции профиля:
сообщение 13.11.2011, 8:53
Сообщение #2


Активный участник
***

Группа: Участник
Сообщений: 297
Регистрация: 23.6.2011
Пользователь №: 2765

Спасибо сказали: 45 раз(а)




Репутация:   3  


Цитата
Мне из 3 колонок одних и тех же надо получить 4

Через UNION вы такого не сделаете. А вводить нулевую колонку - извращение.
Цитата
В первом запросе мне надо получить остатки на начало месяца, во втором на конец месяца

Ну тогда вам надо указывать диапазон, а не просто "<'30.11.2011'" в противном случае вы получаете не только за конец месяца, но вообще за весь месяц и за все предыдущие месяцы.

Покажите структуру этих трех таблиц и как они связаны.
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
NetWorm
  опции профиля:
сообщение 13.11.2011, 8:59
Сообщение #3


Студент
*

Группа: Участник
Сообщений: 24
Регистрация: 2.8.2011
Пользователь №: 2784

Спасибо сказали: 0 раз(а)




Репутация:   0  


Цитата(ilyabvt @ 13.11.2011, 11:53) *
Цитата
Мне из 3 колонок одних и тех же надо получить 4

Через UNION вы такого не сделаете. А вводить нулевую колонку - извращение.
Цитата
В первом запросе мне надо получить остатки на начало месяца, во втором на конец месяца

Ну тогда вам надо указывать диапазон, а не просто "<'30.11.2011'" в противном случае вы получаете не только за конец месяца, но вообще за весь месяц и за все предыдущие месяцы.

Покажите структуру этих трех таблиц и как они связаны.


Я разобрался все!

SELECT 
   query.material,
   query.ed_izm,
   SUM(query.count) AS count1,
   SUM(query.count2) AS count2,
   SUM(query.count3) AS count3,
   SUM(query.count4) AS count4
  

FROM (SELECT
    materials.name AS material,
    SUM(o_sklad.count) AS count,
    ed_izm.name AS ed_izm,
    0 AS count2,
    0 AS count3,
    0 AS count4    
   FROM
    public.o_sklad,
    public.materials,
    public.ed_izm
   WHERE
    o_sklad.id_material = materials.id
    AND materials.id_ed_izm = ed_izm.id
    AND o_sklad.date <='01.11.2011'
   GROUP BY
    materials.name,
    ed_izm.name

   UNION ALL

   SELECT
    materials.name AS material,
    0 AS count,
    ed_izm.name AS ed_izm,
    SUM(o_sklad.count) AS count2,
    0 AS count3,
    0 AS count4
   FROM
    public.o_sklad,
    public.materials,
    public.ed_izm
   WHERE
    o_sklad.id_material = materials.id
    AND materials.id_ed_izm = ed_izm.id
    AND o_sklad.date BETWEEN '01.11.2011' AND '21.11.2011'
    AND o_sklad.type_operacii = 1
   GROUP BY
    materials.name,
    ed_izm.name

   UNION ALL

   SELECT
    materials.name AS material,
    0 AS count,
    ed_izm.name AS ed_izm,
    0 AS count2,
    SUM(o_sklad.count * -1) AS count3,
    0 AS count4
   FROM
    public.o_sklad,
    public.materials,
    public.ed_izm
   WHERE
    o_sklad.id_material = materials.id
    AND materials.id_ed_izm = ed_izm.id
    AND o_sklad.date BETWEEN '01.11.2011' AND '21.11.2011'
    AND o_sklad.type_operacii = 2
   GROUP BY
    materials.name,
    ed_izm.name

   UNION ALL

   SELECT
    materials.name AS material,
    0 AS count,
    ed_izm.name AS ed_izm,
    0 AS count2,
    0 AS count3,
    SUM(o_sklad.count) AS count4    
   FROM
    public.o_sklad,
    public.materials,
    public.ed_izm
   WHERE
    o_sklad.id_material = materials.id
    AND materials.id_ed_izm = ed_izm.id
    AND o_sklad.date BETWEEN '01.11.2011' AND '31.11.2011'
   GROUP BY
    materials.name,
    ed_izm.name

    ) AS query

GROUP BY
   query.material,
      query.ed_izm
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение

Сообщений в этой теме


Быстрый ответОтветить в данную темуНачать новую тему
Теги
Нет тегов для показа


2 чел. читают эту тему (гостей: 2, скрытых пользователей: 0)
Пользователей: 0




RSS Текстовая версия Сейчас: 25.11.2024, 1:17