iDempiere 使用指南 库存出入库研究
Created by 蓝色布鲁斯,QQ32876341,blog http://www.cnblogs.com/zzyan/
iDempiere官方中文wiki主页 http://wiki.idempiere.org/zh
iDempiere 中文社区www.idempiere.org.cn
iDempiere 中文社区QQ群 65713012
本文研究iDempiere的库存出入库机制,主要涉及到2张表格m_storageonhand, m_storagereservation以及视图m_storage。
可以先参照花生的wiki,了解一下这3张表的用途,然后再回来看一下本文的实际测试部分。
http://wiki.idempiere.org/zh/库存管理机制
本测试使用的组织为Fertilizer,warehouse为Fertilizer
由于后面account设置问题,最后一个测试切换到HQ组织进行,但是原理是相同的。
仓库设置locator如下
使用Material Receipt进行一笔接收操作
接收单如下,分别接收到两个locator中,RAW1和RAW2,数量分别为100,200
对接收单执行complete操作。
由于account设置问题,Complete出错,新建PO再建立receipt order操作了
更新代码以后好像出现了一个Counter Document的东西,导致了前面直接建立receipt order出错
接收完成以后,查看物料的库存,可以看到,已经显示库存量增加
可以看到,系统的located at 功能,并没有显示现有量的汇总信息,而是直接显示了每个locator的现有量信息
查看数据库,可以看到,M_Storage是一个视图,定义如下
m_storage由两张表组成,分别是m_storageonhand和m_storagereservation
CREATE OR REPLACE VIEW m_storage AS
SELECT s.m_product_id,
s.m_locator_id,
s.ad_client_id,
s.ad_org_id,
s.isactive,
s.created,
s.createdby,
s.updated,
s.updatedby,
s.qtyonhand,
0 AS qtyreserved,
0 AS qtyordered,
s.datelastinventory,
s.m_attributesetinstance_id,
s.m_storageonhand_uu AS m_storage_uu,
s.datematerialpolicy
FROM m_storageonhand s
UNION ALL
SELECT sr.m_product_id,
w.m_reservelocator_id AS m_locator_id,
sr.ad_client_id,
sr.ad_org_id,
sr.isactive,
sr.created,
sr.createdby,
sr.updated,
sr.updatedby,
0 AS qtyonhand,
sr.qty AS qtyreserved,
0 AS qtyordered,
sr.datelastinventory,
sr.m_attributesetinstance_id,
sr.m_storagereservation_uu AS m_storage_uu,
NULL::timestamp without time zone AS datematerialpolicy
FROM m_storagereservation sr
JOIN m_warehouse w ON sr.m_warehouse_id = w.m_warehouse_id
WHERE sr.issotrx = 'Y'::bpchar AND sr.qty <> 0::numeric
UNION ALL
SELECT so.m_product_id,
w.m_reservelocator_id AS m_locator_id,
so.ad_client_id,
so.ad_org_id,
so.isactive,
so.created,
so.createdby,
so.updated,
so.updatedby,
0 AS qtyonhand,
0 AS qtyreserved,
so.qty AS qtyordered,
so.datelastinventory,
so.m_attributesetinstance_id,
so.m_storagereservation_uu AS m_storage_uu,
NULL::timestamp without time zone AS datematerialpolicy
FROM m_storagereservation so
JOIN m_warehouse w ON so.m_warehouse_id = w.m_warehouse_id
WHERE so.issotrx = 'N'::bpchar AND so.qty <> 0::numeric;
从m_storagereservation的表列信息可以看到,除了基本的onhand信息以外没有源单据的信息,所以没有办法从reservation反向查询到订单等信息
执行前面的接收以后,m_storageonhand增加一行,同时m_transaction也增加一行
查看M_transaciton,可以看到多了一行记录。
从M_transaction表格可以看出,movemnettype有3种,V,M,C,测试对比以后,这3个代码应该代表如下意思。
V 表示Vender
M应该表示move order或者类似的组织/仓库内部移动,代表库存内部移转
C表示Customer,销售订单出货时候,movementtype为 C-
对应的3种主类型后面的信息均包括+/-号,表示该locator的数量值增减

在当前的库存状态下,尝试建立一张standard SO并且进行complete操作,看系统是否会自动进行reservation操作
建立的SO数量为20
SO complete以后,可以看到界面上面reservation qty=20
刷新product界面,查看onhand信息,发现其中一行onhand qty=0的行中,on order qty 变为了38,刚好比刚才多了20个数量,说明reservation记录已经创建。
查看db中的m_reservation表的信息,发现系统更新了reservation行,onhand显示为0,SOTRX=Y,表示这个是一个SO transaction。数量更改为38
对比onhand,发现onhand的信息没有变,仍然是原来的行记录,数量为100
以上界面也说明了我们的m_storage是m_storageonhand和m_reservation两个表的union all。而product info上面的located at信息直接抓取了m_storage视图。
我们再新建一张订单,这时候选择订单类型为POS,同时创建好订单以后执行complete操作,由于是POS订单,所以系统会自动执行出货操作。我们把订单数量设置为17
由于fertilizer的库存组织没有设置account信息,所以SO没有办法complete,直接切换到HQ组织做一次。重新对HQ采购100数量到HQ Warehouse。建立SO,数量17,并尝试complete操作。
Complete了以后,可以看到SO行中的数量信息更改了,deliver qty 为17,表示该数量已经发货。
查看DB,可以看到多了一行m_transaction信息,moveordertype=C-,表示库存减少,类型为Customer。
查看onhand信息,可以看到,系统并没有扣减我们最新的一行记录,而是把我们旧的数据中的一笔记录的数量进行了扣减,说明默认情况下,iDempiere的库存扣减是通过先进后出(FIFO)的方式扣减onhand数量的。
iDempiere 使用指南 库存出入库研究的更多相关文章
- iDempiere 使用指南 绿色版一键启动测试环境
Created by 蓝色布鲁斯,QQ32876341,blog http://www.cnblogs.com/zzyan/ iDempiere官方中文wiki主页 http://wiki.idemp ...
- PDA手持终端在ERP系统仓库管理出入库盘点环节的应用
PDA手持终端在ERP系统仓库管理出入库盘点环节的应用 传统库存管理的数据录入过程,常采用PC机录入数据,或在电脑上结合条码枪扫描条码进行管理(非实时),造成管理上的不便.因而,采用无线(WIFI)手 ...
- PDA应用在WMS仓储管理系统 实现无线扫描出入库作业
WMS系统是根据仓储物流管理的建设实施经验而推出的一款专业化仓储管理软件.与传统进销存软件相比优势在于,其不但包含了正常的出入库.盘点等库存管理基本功能,重点在于可以实现仓库作业过程的管理,通过条码及 ...
- ERP出入库进阶操作与子流程--开源软件诞生28
赤龙ERP出入库进阶讲解--第28篇 用日志记录"开源软件"的诞生 [进入地址 点亮星星]----祈盼着一个鼓励 博主开源地址: 码云:https://gitee.com/redr ...
- 安卓智能POS终端手持机PDA应用仓库出入库,移库,盘点,销售开单系统
随着移动互联网的兴起,目前仓储管理所面临的的问题可以迎刃而解,WMS仓库系统解决方案通过智能终端扫描条码技术应用解决了工作量大导致工作效率不高,以及数据实时传输等问题,该方案主要提供仓库出入库,移库, ...
- iDempiere 使用指南 采购入库流程
Created by 蓝色布鲁斯,QQ32876341,blog http://www.cnblogs.com/zzyan/ iDempiere官方中文wiki主页 http://wiki.idemp ...
- iDempiere 使用指南 BOM及工单流程
Created by 蓝色布鲁斯,QQ32876341,blog http://www.cnblogs.com/zzyan/ iDempiere官方中文wiki主页 http://wiki.idemp ...
- iDempiere 使用指南 使用MRP进行生产及采购排程
Created by 蓝色布鲁斯,QQ32876341,blog http://www.cnblogs.com/zzyan/ iDempiere官方中文wiki主页 http://wiki.idemp ...
- iDempiere 开发指南 Process(iDem后台进程)及插件的开发及部署
Created by 蓝色布鲁斯,QQ32876341,blog http://www.cnblogs.com/zzyan/ iDempiere官方中文wiki主页 http://wiki.idemp ...
随机推荐
- Jupyter Notebook 使用入门
Jupyter Notebook 简介与安装 Jupyter Notebook 是一款开放源代码的 Web 应用程序,可让我们创建并共享代码和文档. 它提供了一个环境,你可以在其中记录代码,运行代码, ...
- Haproxy配置之URL重写,支持websocket
配置文件位置:/etc/haproxy/haproxy.cfg Reqrep 正则重写 配置详情: Frontend App *: acl uri_api path_beg /api/ acl uri ...
- JSP使用Struts2标签库报错
JSP中使用<%@ taglib prefix="s" uri="/struts-tags" %>报错:Cannot find the tag li ...
- MVC5 + EF6 入门完整教程1
https://www.cnblogs.com/miro/p/4030622.html 第0课 从0开始 ASP.NET MVC开发模式和传统的WebForm开发模式相比,增加了很多"约定& ...
- 瀑布模型,(增量开发)渐增式开发,原型化开发,统一过程模型(RUP)
瀑布模型:设计在开发阶段 瀑布模型有以下优点 1)为项目提供了按阶段划分的检查点. 2)当前一阶段完成后,您只需要去关注后续阶段. 3)可在迭代模型中应用瀑布模型. 增量迭代应用于瀑布模型.迭代1解决 ...
- PHP 位运算符
位运算符 位运算符是指对二进制位从低位到高位对齐后进行运算. 符号 作用 举例 个人理解 & 按位与 $m & $n 全1为1,否则为0 | 按位或 $m | $n 全0为0,有1为1 ...
- 补档 Codeblocks下的文件标题栏(标签)显示方法
可能在以下链接也能看到这篇文档 我知道很多人都不知道这个到底叫啥,还不如直接一点: 文件标题栏 就是如下的效果. 解决办法: 在左上角第三个view下,打开后取消Hide editor tabs 选项 ...
- Selenium WebDriver 中鼠标和键盘事件分析及扩展
[From] http://www.51testing.com/html/18/631118-861557.html 在使用 Selenium WebDriver 做自动化测试的时候,会经常模拟鼠标和 ...
- Linux mysql中文乱码问题
1.debian系统 (1)mysql 5.5版本之前 vim /etc/mysql/my.cnf 在 [client] 下面加入 default-character-set=utf8 在 [m ...
- Kafka消费不到数据的特殊情况
我大约是把kafka消费不到数据的特殊情况都经历了一遍了吧= =. kafka消费不到数据的原因,首先检查配置之类的,如是否设置了group.id,对应的topic是否正确等等,这些不多说. 下面是我 ...