最近负责WMS系统 盘点 移库 两个功能模块的功能及数据库设计。
物流仓储系统的搭建,要基于仓库的实际情况,整理内部员工需求,再参考其他WMS系统,经过长时间的讨论和研究,最终转化为产品需求。
这里先简单讲一下库存,但是要讲明白库存,首先要知道出库和入库的流程。
库存表是WMS的核心表,商品的入库 -》 进入库存 =》出库 及盘点、移库、拆分等重要功能都是围绕库存表为核心进行操作的。
下图为网上WMS系统的实际模板,一个入库单含有多个入库明细信息,出库单同理。
他们之间的关系如下:
入库表 : 入库明细表 出库表 : 出库明细表 入库明细 : 库存 : 出库明细
1 : n 1 : n 1 : 1 : n
一、库存
必须的属性如下,很多其他属性、比如体积毛重、备案序号、商品料号等,这里进行省略。
库存表(ID、仓库ID、仓位ID、商品ID、库存数量、数量单位、入库ID、入库明细ID、入库时间)
ps. 1 数量单位 和 入库ID是冗余字段,方便盘点和移库获取。
ps. 2 库存表的 入库明细ID 用于查询入库记录
ps. 3 出库明细有一个 库存ID 用于查询出库记录
二、盘点
盘点表(ID、仓库ID、状态、库存数量、盘点数量、盘盈数量、盘亏数量、备注、盘点人、盘点日期)
盘点明细表(ID、盘点表ID、仓位ID、商品ID、入库单号、库存数量、盘点数量、盘盈数量、盘亏数量、数量单位、备注)
ps 状态:1未确认 2已确认 3无差异 4有差异
在仓库管理过程中,每隔一段时间需要盘点一下仓库的货物是否准确。
仓管员创建盘点单,选择库存(一般是当前仓库所有库存,或者是A区、B区等等区域划分)。
仓管员根据盘点单信息,进行手动/扫描盘点,对应清点数量是否一致。如果一致则盘点完成无差异;如不一致,需要向上级汇报。
盘点明细表中的信息只有盘点数量和备注可填、其他都由库存表带出,盘盈盘亏自动计算。确认盘点后除盘点表-备注外所有信息无法修改。
具体功能流程如下:
三、移库
移库表(ID、仓库ID、已移库、备注、移库人、移库日期)
移库明细表(ID、移库单ID、商品ID、入库单号、原仓位ID、移入仓位ID、数量单位、库存表ID、备注)
库存表ID:关联库存表,确认拆库库后,方便移动库存。
在仓库管理过程中,有可能客户有要求,或者自己需要把商品分库分门别类堆放,需要移库操作。
仓管员创建移库单,选择库存(一般是当前仓库所有库存,或者是A区、B区等等区域划分)。
仓管员根据移库单信息,进行移库,移库明细表中的信息只有移入仓位和备注可填、其他都由库存表带出,确认移库后除移库表-备注外所有信息无法修改。
具体功能流程如下:
四、拆库
必须的属性如下,很多其他属性、比如体积毛重等,这里进行省略。
拆库表(ID、仓库ID、已拆库、库存数量、备注、拆库人、拆库日期)
拆库明细表(ID、拆库单ID、目标仓位ID、拆分数量、备注)
仓管员创建拆库单,查询库存表,选择原库位,添加1-N个目标库位,填写拆分数量、体积、毛重等。
仓管员根据移库单信息,进行移库,操作后确认无误就确认拆库完成。
库存表修改为拆分后的数量、体积,并根据拆库明细生成新的库存。
确认拆库后除拆库表-备注外所有信息无法修改。
具体功能流程如下:
五、库存历史记录表
表字段如下
出入库明细(变更类型)为: 入库 上架 出库
库内明细(变更类型)为: 移库 拆库
在每次对库存有改变的操作时 就写入记录表