Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Прочее";
Текущий архив: 2010.08.27;
Скачать: [xml.tar.bz2];

Вниз

SQL остаток товара на складе   Найти похожие ветки 

 
worldmen   (2010-04-28 12:32) [0]

Есть 3 БД:
1-я Наименование товара-
TOVAR
   ID,
   NAME
2-я Кол-во товара которое было принято
TOVAR_IN
   IDFK    
   KOLVO  
   PRICE_IN
   PRICE_OUT
   DATA_IN
3-я кол-во проданного товара
TOVAR_OUT
   IDFK      
   PRICE_OUT  
   DATA_OUT  
   KOLVO      
Нужно сделать запрос остатка товаров на складе.
Я уже и с JOIN пробовал, неполучается.

select a.id, a.name, b.kolvo
from tovar a
RIGHT JOIN tovar_in b on b.idfk=a.id
group by a.id, a.name, b.kolvo
order by a.name

Для начала у меня получается так:

ID..NAME..................... KOLVO
3..Athlon 5000................50  
4..Core 2 Duo.................20  
2..Блок питания 300V.......5  
1..Блок питания 400V.......2  
1..Блок питания 400V......10  

А должно быть сгрупировано две последних записи, почему они не группируются?


 
sniknik ©   (2010-04-28 12:43) [1]

> почему они не группируются?
количество разное, вот и не группируются > group by a.id, a.name, b.kolvo
группировка делается только по полностью совпавшим значениям


 
worldmen   (2010-04-28 13:04) [2]

А если убрать b.kolvo, то появляется ошибка: "invalid column reference."
Как тогда правильно сгруппировать?


 
worldmen   (2010-04-28 13:14) [3]

там надо было :
sum(b.kolvo)
Буду думать дальше.


 
Плохиш ©   (2010-04-28 13:15) [4]


> А должно быть сгрупировано две последних записи, почему
> они не группируются?

А в чём у вас сакраменный смысл группировки?


 
Sergey13 ©   (2010-04-28 13:34) [5]

> [0] worldmen   (28.04.10 12:32)
> 2-я Кол-во товара которое было принято
> 3-я кол-во проданного товара

Почему не в ОДНОЙ таблице? Тогда и думать бы не надо было. 8-)


 
Anatoly Podgoretsky ©   (2010-04-28 14:35) [6]

А чего тут думать, есть такое понятие соединение, после чего мы имеем ОДНУ таблицу


 
Anatoly Podgoretsky ©   (2010-04-28 14:36) [7]


> 1..Блок питания 400V.......2  
> 1..Блок питания 400V......10  

А с чего бы им группироватся, это разные записи. Тут надо использовать аггрегатную функцию SUM(b.kolvo)


 
xayam ©   (2010-04-28 14:50) [8]


> Sergey13 ©   (28.04.10 13:34) [5]
> > [0] worldmen   (28.04.10 12:32)
> > 2-я Кол-во товара которое было принято
> > 3-я кол-во проданного товара
> Почему не в ОДНОЙ таблице? Тогда и думать бы не надо было.
>  8-)

ага точно, плохая структура базы


 
worldmen   (2010-04-28 14:57) [9]


> Почему не в ОДНОЙ таблице? Тогда и думать бы не надо было.
>  8-)

Потому что, товар один и тот же закупается в разное время и по разным ценам.
> Тут надо использовать аггрегатную функцию SUM(b.kolvo)

Я в [3] уже написал это. Читайте внимательно.


 
xayam ©   (2010-04-28 15:01) [10]


> Потому что, товар один и тот же закупается в разное время
> и по разным ценам.

у тебя же все поля одни и те же, достаточно одной таблицы с такими же полями + поле для указания направления движения товара (два значения: IN и OUT)


 
worldmen   (2010-04-28 15:04) [11]

У МЕНЯ ВСЕ ПОЛУЧИЛОСЬ.

select a.id, a.name, sum(b.kolvo) klIN,sum(c.kolvo) klOut, (sum(b.kolvo)-sum(c.kolvo)) Sklad
from tovar a
RIGHT JOIN tovar_in b on b.idfk=a.id
left JOIN tovar_out c on c.idfk=a.id
group by a.id, a.name
order by a.name

РЕЗУЛЬТАТ

ID  NAME               KLIN  KLOUT  SKLAD
3  Athlon 5000          50                
4  Core 2 Duo           20      2     18  
2  Блок питания 300V     5                
1  Блок питания 400V    12                

А структура БД самая правильная. Вы просто никто не читали о нормальных формах.


 
worldmen   (2010-04-28 15:08) [12]


> у тебя же все поля одни и те же, достаточно одной таблицы
> с такими же полями + поле для указания направления движения
> товара (два значения: IN и OUT)

Т.е. сделать вместо tovar_in и tovar_out одну таблицу с полем в котором будет указано тип - ушел/пришел товар?
Тоже хорошо. Но думаю запрос был бы сложнее.


 
xayam ©   (2010-04-28 15:11) [13]


> worldmen   (28.04.10 15:08) [12]
> А структура БД самая правильная. Вы просто никто не читали
> о нормальных формах.

это сильно, к сведению мы об этом не только читали, но и не раз обсуждали, если же ты прочитал про это - не значит что у тебя правильно. Во-первых, потому что не соблюдается принцип одного корня (а как раз их у тебя 2) и, во-вторых, sql-запрос слишком сложен для такого простого результата, соответственно если данных много, то ничего хорошего не будет.


 
Petr V. Abramov ©   (2010-04-28 15:20) [14]


> worldmen   (28.04.10 15:08) [12]


> Т.е. сделать вместо tovar_in и tovar_out одну таблицу с
> полем в котором будет указано тип - ушел/пришел товар?

пришло - kol_vo со знаком плюс, ушло - со знаком минус
запрос становится тривиальным - select sum(kov_vo) from table1 group by fk_id


 
xayam ©   (2010-04-28 15:25) [15]


> пришло - kol_vo со знаком плюс, ушло - со знаком минус

ну да так даже лучше


 
worldmen   (2010-04-28 15:33) [16]

> пришло - kol_vo со знаком плюс, ушло - со знаком минус
Только потом с минусами мучится, когда нужно выводить сколько ушло.
В SQLе ведь нет модуля числа. Во всяком случае в InterBase


 
xayam ©   (2010-04-28 15:37) [17]


> xayam ©   (28.04.10 15:25) [15]
> > пришло - kol_vo со знаком плюс, ушло - со знаком минус
> ну да так даже лучше

но поле для направления движения лучше сохранить, можно использовать для статуса: ЗАКАЗАЛИ, ПРИШЛО НА СКЛАД, ВЫВЕЗЛИ В ЗАЛ, ПРОДАЛИ и так по кругу. У нас так в магазине и это поле в некоторых местах отображается.


 
Petr V. Abramov ©   (2010-04-28 15:37) [18]


> Только потом с минусами мучится, когда нужно выводить сколько
> ушло.

select -kov_vo
from table1
where kol_vo < 0
 and прочие условия

:)


 
xayam ©   (2010-04-28 15:41) [19]

в интербайсе такого нет :) так и запишем.


 
Petr V. Abramov ©   (2010-04-28 15:46) [20]


> xayam ©   (28.04.10 15:37) [17]


> можно использовать для статуса: ЗАКАЗАЛИ, ПРИШЛО НА СКЛАД,
>  ВЫВЕЗЛИ В ЗАЛ, ПРОДАЛИ и так по кругу.

а потом возникнут вопросы у кого заказали, на какой склад пришло, в какой зал вывезли, кому продали и так по кругу :)


 
xayam ©   (2010-04-28 17:05) [21]

а кому щас легко?


 
tesseract ©   (2010-04-28 17:49) [22]


> а потом возникнут вопросы у кого заказали,


Сначала возникнет вопрос - какого черта так долго примитивные остатки формируются и накладные по полдня проводится. Таки срезы придется делать по-любому.


 
oldman ©   (2010-04-28 18:46) [23]


> worldmen   (28.04.10 15:04) [11]
> А структура БД самая правильная.


Абсолютно неправильная.
Не нужно там 3 таблицы. Достаточно одной.

id (обязателен-ли?)
name
date_in
kolvo_in
price_in
date_out
kolvo_out
price_out

Все твои проблемы решаются вычисляемыми полями без всяких запросов.


 
Anatoly Podgoretsky ©   (2010-04-28 19:18) [24]

> xayam  (28.04.2010 15:01:10)  [10]

У него связь один ко многим, нельзя в одну таблицу.


 
Anatoly Podgoretsky ©   (2010-04-28 19:21) [25]

> worldmen  (28.04.2010 15:33:16)  [16]

Это его не красит.


 
MsGuns ©   (2010-04-28 20:31) [26]

Блин, еще один складописатель :)


 
oldman ©   (2010-04-28 20:56) [27]

Удалено модератором


 
Petr V. Abramov ©   (2010-04-28 21:35) [28]

Удалено модератором



Страницы: 1 вся ветка

Форум: "Прочее";
Текущий архив: 2010.08.27;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.51 MB
Время: 0.057 c
2-1265981290
Mestar
2010-02-12 16:28
2010.08.27
1C и Delphi


15-1262219675
Petr V. Abramov
2009-12-31 03:34
2010.08.27
закрывается Игналинская АЭС


2-1265467771
tippa
2010-02-06 17:49
2010.08.27
моделирование логики программы


6-1218021112
StranNik
2008-08-06 15:11
2010.08.27
Вопрос по IdHTTPProxyServer


2-1266912051
serko
2010-02-23 11:00
2010.08.27
Как скопировать текст из другого приложения?





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский