亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > SQL Server > 正文

SQL語句練習實例之五 WMS系統中的關于LIFO或FIFO的問題分析

2024-08-31 00:57:55
字體:
來源:轉載
供稿:網友

復制代碼 代碼如下:


---在倉儲管理中經常會碰到的一個問題

一、關于LIFO與FIFO的簡單說明
---FIFO: First in, First out.先進先出。
---LIFO: Last in, First out.后進先出。

--如貨物A:本月1日購買10件,單價10元/件,3日購買20件,單價15元/件;10日購買10件,單價8元/件。
--本月15日發貨35件。

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


二、示例

復制代碼 代碼如下:


--------
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
----此時如果在2011-8-8賣出300件產品,那么應該如何計算庫存銷售的價值呢?
----1使用當前的替換成本,2011-8-8時每件產品的成本為8,就是說你這300件產品,成本價值為2400
----2使用當前的平均成本單價,一共有420,總成本為6530,平均每件的成本為15.55
----1.LIFO (后進先出)
----2011-8-8 110 *8
----2011-7-7 75*17
----2011-6-6 65*30
----2011-5-5 50*10
-----總成本為 4605
-----2.FIFO(先進先出)
---- '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
-----找出滿足訂單的、足夠存貨的最近日期。如果運氣好的話,某一天的庫存數量正好與訂單要求的數字完全一樣
-----就可以將總成本作為答案返回。如果訂單止的數量比庫存的多,什么也不返回。如果某一天的庫存數量比訂單數量多
---則看一下當前的單價,乘以多出來的數量,并減去它。
---下面這些查詢和視圖只是告訴我們庫存商品的庫存價值,注意,這些查詢與視圖并沒有實際從庫存中向外發貨。
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
-----
-----在發貨之后,實時更新庫存表
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
---------------


三、使用“貪婪算法”進行訂單配貨

復制代碼 代碼如下:


-------還有一個問題,如何使用空間最小或最大的倉庫中的貨物來滿足訂單,假設倉庫不是順序排列,你可以按鈕希望的順序任意選擇滿足訂單。
---使用最小的倉庫可以為訂單的裝卸工人帶來最小的工作量,使用最大的倉庫,則可以在倉庫中清理出更多的空間
-------例如:對于這組數據,你可以使用(1,2,3,4,5,6,7)號倉庫也可以使用(5,6,7,8)號倉庫中的貨物來滿足訂單的需求。
----這個就是裝箱問題,它屬于NP完全系統問題。對于一般情況來說,這種問題很難解決,因為要嘗試所有的組合情況,而且如果數據量大的話,
----計算機也很難很快處理。
---所以有了“貪婪算法”,這個算法算出來的常常是近乎最優的。這個算法的核心就是“咬最大的一口”直到達到或超越目標。
---
--1. 第一個技巧,要在表中插入一些空的啞倉庫,如果你最多需要n次挑選,則增加n-1個啞倉庫
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.id<0 then 0 else w1.id end as bin1 ,w1.qty as qty1,
case when w2.id<0 then 0 else w2.id end as bin2,w2.qty as qty2
,case when w3.id<0 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.使用存儲過程來找出滿足或接近某一數量的挑選組合
--------
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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
黄色一区二区在线观看| 97视频在线免费观看| 欧美与黑人午夜性猛交久久久| 久久人人爽亚洲精品天堂| 久久综合九色九九| 国产精品免费看久久久香蕉| 欧美日韩亚洲国产一区| 国产亚洲精品成人av久久ww| 国产午夜精品视频| 色偷偷亚洲男人天堂| 久久这里只有精品视频首页| 久久综合国产精品台湾中文娱乐网| 成人免费在线视频网址| 精品久久久国产| 91美女福利视频高清| 成人激情视频网| 久久免费成人精品视频| 成人激情视频在线观看| 成人福利在线观看| 亚洲人成啪啪网站| 国产精品老女人精品视频| 在线精品国产欧美| 日韩精品免费综合视频在线播放| 欧美大片va欧美在线播放| 国产欧美 在线欧美| 国内偷自视频区视频综合| 在线播放国产一区中文字幕剧情欧美| 日韩中文字幕第一页| 国产精品91视频| 亚洲色图偷窥自拍| 欧美精品免费在线观看| 久久五月天综合| 97视频在线看| 亚洲国产精品成人一区二区| 国产精品丝袜久久久久久高清| 91在线高清免费观看| 欧美插天视频在线播放| 成人激情在线播放| 91色中文字幕| 九九热这里只有在线精品视| 国产v综合ⅴ日韩v欧美大片| 色婷婷**av毛片一区| 98午夜经典影视| 国产精品美女午夜av| 国产精品一区二区3区| 国产盗摄xxxx视频xxx69| 亚洲性生活视频在线观看| 国内精品伊人久久| 亚洲免费视频在线观看| 国产一区视频在线播放| 成人国产亚洲精品a区天堂华泰| 一区二区三区 在线观看视| 欧美性视频精品| 国产精品视频久| 欧美精品在线免费| 日本久久中文字幕| 久久视频在线视频| 国产精品久久久久久久7电影| 狠狠躁夜夜躁人人爽天天天天97| 国产一级揄自揄精品视频| 91九色国产在线| 久久这里有精品视频| 欧美区二区三区| 中文字幕不卡在线视频极品| 亚洲一区二区三区久久| 激情懂色av一区av二区av| 91久久精品日日躁夜夜躁国产| 亚洲精品suv精品一区二区| 色综合久久精品亚洲国产| 国产精品视频999| 欧美亚洲在线观看| 日韩av高清不卡| 欧美美女18p| 欧美日本黄视频| 欧美激情欧美激情在线五月| 黑人巨大精品欧美一区二区一视频| 久久久久国色av免费观看性色| 精品中文视频在线| 日韩av网址在线观看| 色婷婷亚洲mv天堂mv在影片| 久久在线免费观看视频| 亚洲成人1234| 97在线视频免费播放| 自拍视频国产精品| 亚洲欧美激情视频| 欧美一级成年大片在线观看| 色青青草原桃花久久综合| 欧美激情18p| 欧美午夜xxx| 在线观看亚洲视频| 97久久精品在线| 疯狂做受xxxx欧美肥白少妇| 亚洲天堂免费视频| 日韩精品久久久久久久玫瑰园| 91av视频在线| 91tv亚洲精品香蕉国产一区7ujn| 亚洲成avwww人| 欧美裸体视频网站| 亚洲激情视频网站| 亚洲精品视频播放| 国产精品激情自拍| 国产999精品久久久影片官网| 欧美性一区二区三区| 北条麻妃在线一区二区| 亚洲国产99精品国自产| 欧美黑人性视频| 欧美亚洲激情视频| 色偷偷av一区二区三区| 精品国偷自产在线视频99| 欧美性猛交99久久久久99按摩| 国产精品露脸自拍| 日韩精品一区二区三区第95| 国产精品福利无圣光在线一区| 亚洲精品97久久| 日本精品在线视频| 欧美一级淫片丝袜脚交| 日韩在线一区二区三区免费视频| 国产一区二区三区在线观看网站| 亚洲久久久久久久久久| 91av视频在线免费观看| 国产日韩欧美电影在线观看| 一区二区三区美女xx视频| 欧美日本黄视频| 国产精品91久久久| 日韩精品在线免费观看视频| 欧美日韩国产在线播放| 成人国产精品免费视频| 日韩精品电影网| 国产日韩欧美在线观看| 久久久中精品2020中文| 国产视频久久久| 国产精品高清网站| 一区二区三区四区精品| 自拍亚洲一区欧美另类| 午夜美女久久久久爽久久| 亚洲系列中文字幕| 亚洲人成人99网站| 2024亚洲男人天堂| 欧美性猛交xxxx黑人猛交| 欧美大片免费观看在线观看网站推荐| 欧美电影在线观看网站| 国外成人在线播放| 国产激情视频一区| 色天天综合狠狠色| 亚洲国产精品久久91精品| 久久人人爽人人爽人人片av高请| 国产精品白丝jk喷水视频一区| 欧美日本中文字幕| 亚洲女在线观看| 高清日韩电视剧大全免费播放在线观看| 日韩av日韩在线观看| 亚洲少妇中文在线| 亚洲国产毛片完整版| 97视频人免费观看| 国产精品96久久久久久| 日本精品一区二区三区在线播放视频| 狠狠躁18三区二区一区| 日本韩国在线不卡| 国产精品美腿一区在线看| 欧美日韩国产成人| 丝袜一区二区三区| 久久免费视频这里只有精品| 欧美国产日韩精品| 日韩在线视频导航|