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'" в противном случае вы получаете не только за конец месяца, но вообще за весь месяц и за все предыдущие месяцы.

Покажите структуру этих трех таблиц и как они связаны.
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение

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


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


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




RSS Текстовая версия Сейчас: 28.11.2024, 20:18