主頁(yè) > 知識(shí)庫(kù) > SQL語(yǔ)句練習(xí)實(shí)例之五 WMS系統(tǒng)中的關(guān)于LIFO或FIFO的問(wèn)題分析

SQL語(yǔ)句練習(xí)實(shí)例之五 WMS系統(tǒng)中的關(guān)于LIFO或FIFO的問(wèn)題分析

熱門(mén)標(biāo)簽:al智能電話(huà)機(jī)器人 成都電話(huà)外呼系統(tǒng)一般多少錢(qián) 蘭州語(yǔ)音外呼系統(tǒng)運(yùn)營(yíng)商 陜西電銷(xiāo)外呼系統(tǒng)好用嗎 如何做地圖標(biāo)注圖鋪 沒(méi)聽(tīng)見(jiàn)電話(huà)機(jī)器人幫你接 銀川高頻外呼回?fù)芟到y(tǒng)多少錢(qián) 最新人工智能電銷(xiāo)機(jī)器人 數(shù)字匠心電銷(xiāo)機(jī)器人
復(fù)制代碼 代碼如下:

---在倉(cāng)儲(chǔ)管理中經(jīng)常會(huì)碰到的一個(gè)問(wèn)題

一、關(guān)于LIFO與FIFO的簡(jiǎn)單說(shuō)明
---FIFO: First in, First out.先進(jìn)先出。
---LIFO: Last in, First out.后進(jìn)先出。

--如貨物A:本月1日購(gòu)買(mǎi)10件,單價(jià)10元/件,3日購(gòu)買(mǎi)20件,單價(jià)15元/件;10日購(gòu)買(mǎi)10件,單價(jià)8元/件。
--本月15日發(fā)貨35件。

--按FIFO先進(jìn)先出,就是先購(gòu)入的存貨先發(fā)出,所以,先發(fā)1日進(jìn)貨的10件,再發(fā)3日進(jìn)貨的20件,最后發(fā)10日進(jìn)貨的5件,發(fā)出成本共為:10*10+20*15+5*8=440元。
--按LIFO后進(jìn)先出,就是后購(gòu)入的存貨先發(fā)出,所以,先發(fā)10日進(jìn)貨的10件,再發(fā)3日進(jìn)貨的20件,最后發(fā)1日進(jìn)貨的5件,發(fā)出成本共為:10*8+20*15+5*10=430元

二、示例
復(fù)制代碼 代碼如下:

--------
Create table stock
(Id int not null primary key,
articleno varchar(20) not null,
rcvdate datetime not null,
qty int not null,
unitprice money not null
)
go
----
insert stock
select 1,'10561122','2011-1-1',15,10 union
select 2,'10561122','2011-2-2',25,12 union
select 3,'10561122','2011-3-3',35,15 union
select 4,'10561122','2011-4-4',45,20 union
select 5,'10561122','2011-5-5',55,10 union
select 6,'10561122','2011-6-6',65,30 union
select 7,'10561122','2011-7-7',75,17 union
select 8,'10561122','2011-8-8',110,8

go
----此時(shí)如果在2011-8-8賣(mài)出300件產(chǎn)品,那么應(yīng)該如何計(jì)算庫(kù)存銷(xiāo)售的價(jià)值呢?
----1使用當(dāng)前的替換成本,2011-8-8時(shí)每件產(chǎn)品的成本為8,就是說(shuō)你這300件產(chǎn)品,成本價(jià)值為2400
----2使用當(dāng)前的平均成本單價(jià),一共有420,總成本為6530,平均每件的成本為15.55
----1.LIFO (后進(jìn)先出)
----2011-8-8 110 *8
----2011-7-7 75*17
----2011-6-6 65*30
----2011-5-5 50*10
-----總成本為 4605
-----2.FIFO(先進(jìn)先出)
---- '2011-1-1',15*10
--- '2011-2-2',25*12
-----'2011-3-3',35*15
-----'2011-4-4',45*20
-----'2011-5-5',55*10
-----'2011-6-6',65*30
-----'2011-7-7',65*17
----總成本為5480

---成本視圖
create view costLIFO
as
select unitprice from stock
where rcvdate= (select MAX(rcvdate) from stock)
go
create view costFIFO
as
select sum(unitprice*qty)/SUM(qty) as unitprice from stock

go
-----找出滿(mǎn)足訂單的、足夠存貨的最近日期。如果運(yùn)氣好的話(huà),某一天的庫(kù)存數(shù)量正好與訂單要求的數(shù)字完全一樣
-----就可以將總成本作為答案返回。如果訂單止的數(shù)量比庫(kù)存的多,什么也不返回。如果某一天的庫(kù)存數(shù)量比訂單數(shù)量多
---則看一下當(dāng)前的單價(jià),乘以多出來(lái)的數(shù)量,并減去它。
---下面這些查詢(xún)和視圖只是告訴我們庫(kù)存商品的庫(kù)存價(jià)值,注意,這些查詢(xún)與視圖并沒(méi)有實(shí)際從庫(kù)存中向外發(fā)貨。
create view LIFO
as
select s1.rcvdate,s1.unitprice,sum(s2.qty) as qty,sum(s2.qty*s2.unitprice) as totalcost
from stock s1 ,stock s2
where s2.rcvdate>=s1.rcvdate
group by s1.rcvdate,s1.unitprice

go
select (totalcost-((qty-300)*unitprice )) as cost
from lifo as l
where rcvdate=(select max(rcvdate) from lifo as l2 where qty>=300)
go

create view FIFO
as
select s1.rcvdate,s1.unitprice,sum(s2.qty) as qty,sum(s2.qty*s2.unitprice) as totalcost
from stock s1 ,stock s2
where s2.rcvdate=s1.rcvdate
group by s1.rcvdate,s1.unitprice

go
select (totalcost-((qty-300)*unitprice )) as cost
from fifo as l
where rcvdate=(select min(rcvdate) from lifo as l2 where qty>=300)
--------
go
-----
-----在發(fā)貨之后,實(shí)時(shí)更新庫(kù)存表
create view CurrStock
as
select s1.rcvdate,SUM(case when s2.rcvdate>s1.rcvdate then s2.qty else 0 end) as PrvQty
,SUM(case when s2.rcvdate=s1.rcvdate then s2.qty else 0 end) as CurrQty
from stock s1 ,stock s2
where s2.rcvdate=s1.rcvdate
group by s1.rcvdate,s1.unitprice
go
create proc RemoveQty
@orderqty int
as
if(@orderqty>0)
begin
update stock set qty =case when @orderqty>=(select currqty from CurrStock as c where c.rcvdate=stock.rcvdate)
then 0
when @orderqty(select prvqty from CurrStock c2 where c2.rcvdate=stock.rcvdate)
then stock.qty
else (select currqty from CurrStock as c3 where c3.rcvdate=stock.rcvdate)
-@orderqty end
end
--
delete from stock where qty=0
---
go
exec RemoveQty 20
go
---------------

三、使用“貪婪算法”進(jìn)行訂單配貨

復(fù)制代碼 代碼如下:

-------還有一個(gè)問(wèn)題,如何使用空間最小或最大的倉(cāng)庫(kù)中的貨物來(lái)滿(mǎn)足訂單,假設(shè)倉(cāng)庫(kù)不是順序排列,你可以按鈕希望的順序任意選擇滿(mǎn)足訂單。
---使用最小的倉(cāng)庫(kù)可以為訂單的裝卸工人帶來(lái)最小的工作量,使用最大的倉(cāng)庫(kù),則可以在倉(cāng)庫(kù)中清理出更多的空間
-------例如:對(duì)于這組數(shù)據(jù),你可以使用(1,2,3,4,5,6,7)號(hào)倉(cāng)庫(kù)也可以使用(5,6,7,8)號(hào)倉(cāng)庫(kù)中的貨物來(lái)滿(mǎn)足訂單的需求。
----這個(gè)就是裝箱問(wèn)題,它屬于NP完全系統(tǒng)問(wèn)題。對(duì)于一般情況來(lái)說(shuō),這種問(wèn)題很難解決,因?yàn)橐獓L試所有的組合情況,而且如果數(shù)據(jù)量大的話(huà),
----計(jì)算機(jī)也很難很快處理。
---所以有了“貪婪算法”,這個(gè)算法算出來(lái)的常常是近乎最優(yōu)的。這個(gè)算法的核心就是“咬最大的一口”直到達(dá)到或超越目標(biāo)。
---
--1. 第一個(gè)技巧,要在表中插入一些空的啞倉(cāng)庫(kù),如果你最多需要n次挑選,則增加n-1個(gè)啞倉(cāng)庫(kù)
insert stock
select -1,'10561122','1900-1-1',0,0 union
select -2,'10561122','1900-1-1',0,0
--select -3,'1900-1-1',0,0
----
go
create view pickcombos
as
select distinct (w1.qty+w2.qty+w3.qty) as totalpick
,case when w1.id0 then 0 else w1.id end as bin1 ,w1.qty as qty1,
case when w2.id0 then 0 else w2.id end as bin2,w2.qty as qty2
,case when w3.id0 then 0 else w3.id end as bin3 ,w3.qty as qty3
from stock w1,stock w2, stock w3
where w1.id not in (w2.id,w3.id)
and w2.id not in (w1.id,w3.id)
and w1.qty>=w2.qty
and w2.qty>=w3.qty
----
---1.使用存儲(chǔ)過(guò)程來(lái)找出滿(mǎn)足或接近某一數(shù)量的挑選組合
--------
go
create proc OverPick
@pickqty int
as
if(@pickqty>0)
begin
select @pickqty,totalpick,bin1,qty1,bin2,qty2,bin3,qty3
from pickcombos
where totalpick=(select MIN(totalpick) from pickcombos where totalpick>=@pickqty)
end
go
exec OverPick 180

----------
select * from stock
drop table stock
drop view lifo
drop view fifo
drop view costfifo
drop view costlifo
drop view CurrStock
drop proc OverPick
drop proc RemoveQty
drop view pickcombos
您可能感興趣的文章:
  • oracle—SQL技巧之(二)WMSYS.WM_CONCAT函數(shù)實(shí)現(xiàn)多行記錄用逗號(hào)拼接在一起
  • mysql 一個(gè)較特殊的問(wèn)題:You can''t specify target table ''wms_cabinet_form''
  • woso.exe,wlso.exe,wmso.exe, woso.exe,ztso.exe 等木馬盜號(hào)病毒專(zhuān)殺工具
  • iwms access與sql版的安裝與轉(zhuǎn)換
  • Android自定義Toast之WindowManager
  • Android利用WindowManager實(shí)現(xiàn)懸浮窗
  • 深入理解Android中的Window和WindowManager
  • Android利用WindowManager生成懸浮按鈕及懸浮菜單
  • 在當(dāng)前Activity之上創(chuàng)建懸浮view之WindowManager懸浮窗效果
  • Android中WindowManager與WMS的解析

標(biāo)簽:鹽城 本溪 通化 宜春 邢臺(tái) 遼源 巴彥淖爾 朔州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《SQL語(yǔ)句練習(xí)實(shí)例之五 WMS系統(tǒng)中的關(guān)于LIFO或FIFO的問(wèn)題分析》,本文關(guān)鍵詞  SQL,語(yǔ)句,練習(xí),實(shí)例,之五,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《SQL語(yǔ)句練習(xí)實(shí)例之五 WMS系統(tǒng)中的關(guān)于LIFO或FIFO的問(wèn)題分析》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于SQL語(yǔ)句練習(xí)實(shí)例之五 WMS系統(tǒng)中的關(guān)于LIFO或FIFO的問(wèn)題分析的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章