Inventory of the materials to teach you how to query a date certain combination of dimensions
Please correct me if any omission or error
From the Inventory Management-> journals-> Item Counting> Counting can enter the inventory:
Lines can create a new inventory record, click into the inventory:
Need to be aware that disk Points: changes in the respective fields, will be updated in real time.
Basically every field modified method of the corresponding field in the data source will triggerto update disk Points:
The inventory part by class: InventMov_Jour_Loss_SumUp, control, it is a subclass ofinventmov_journal InventMovement subclass inventmov_journal.
InventMov_Jour_Loss_SumUp use: InventQty dateOnHandPhysical (InventDim _inventDim) disc calculatorspoints,
Which in turn calls a static method of InventSumDatePhysicalDim:
server static InventQty onHandQty (
TransDate _transDate
ItemId _itemId
InventDim _inventDim
InventDimParm _inventDimParm
)
To calculate the static method to invoke class: InventSumDatePhysicalDim this class inherits fromInventSumDatePhysical, which is responsible for the combined dimension to query the amount of materials.
Declare a the class inventmov_journal statement:
InventJournalTrans inventJournalTrans;
When entering the inventory row will operate the inventJournalTrans
First of all:
When you create a new inventory record is triggered to calculate the plate number of points, then used inventDim inventDim InventMovement declared InventMovement:
InventDim inventdim (InventDim _inventDim = inventDim)
{
;
inventDim = _inventDim;
if (! inventDim)
inventDim = InventDim :: find (this.inventDimId ());
return inventDim;
}
To get inventDim! inventDim will call table: find inventDim:
static public InventDim find (InventDimId inventDimId, boolean _forupdate = false)
{
InventDim inventDim;
;
if (inventDimId)
{
if (_forupdate)
inventDim.selectForUpdate (_forupdate);
select firstonly inventDim
index hint DimIdIdx
where inventDim.InventDimId The == inventDimId;
}
return inventDim;
}
In this way, you will know:
InventQty dateOnHandPhysical (InventDim _inventDim)
The parameters from there, you get your new a new definition inventdim, you add two records record the actual modify this inventdim.
Then:
InventQty dateOnHandPhysical (InventDim _inventDim)
{
InventDimParm _inventDimParm;
;
/ / Lower sentence based on previous inventDim construct a _InventDimParm of
_inventDimParm.initFromInventDim (_inventDim);
_inventDimParm = InventDimParm :: orParms (_inventDimParm, InventJournalTable :: journalId2inventDimParm (inventJournalTrans.JournalId));
return InventSumDatePhysicalDim :: onHandQty (inventJournalTrans.TransDate, inventJournalTrans.ItemId, _inventDim, _inventDimParm);
}
This code: InventJournalTable :: journalId2inventDimParm:
static InventDimParm journalId2inventDimParm (InventJournalId inventJournalId)
{
InventDimParm inventDimParm;
;
InventDimFixedClass :: inventDimFixed2InventDimParm (InventJournalTable :: find (inventJournalId). InventDimFixed, inventDimParm);
return inventDimParm;
}
The based of the field InventDimFixed inventJournalTable to construct a inventDimParm.
This field is derived from this:
When you create a new record will pop up:
InventDimFixed is an integer of 0 to 255, on eight dimensions, respectively, corresponding to 8bits in a byte, if the dimension is selected, this bit is:
|
Color |
Size |
Config |
Serial |
Pallet |
Location |
Batch |
warehouse |
|
128 |
64 |
32 |
16 |
8 |
4 |
2 |
1 |
InventJournalTable the call InventDimFixedClass class to initial this field, the core of the code is:
InventDimFixed inventDimFixed ()
{
InventDimFixed inventDimFixed;
;
# InventDimDevelop
if (inventDimParm.inventLocationIdFlag) inventDimFixed = InventDimFixedClass :: setField (inventDimFixed, # INVENTLOCATIONID_IDX);
if (inventDimParm.inventBatchIdFlag) inventDimFixed = InventDimFixedClass :: setField (inventDimFixed, # BATCH_IDX);
if (inventDimParm.WMSLocationIdFlag) inventDimFixed = InventDimFixedClass :: setField (inventDimFixed, # LOCATION_IDX);
if (inventDimParm.WMSPalletIdFlag) inventDimFixed = InventDimFixedClass :: setField (inventDimFixed, # PALLET_IDX);
if (inventDimParm.inventSerialIdFlag) inventDimFixed = InventDimFixedClass :: setField (inventDimFixed, # SERIALID_IDX);
if (inventDimParm.configIdFlag) inventDimFixed = InventDimFixedClass :: setField (inventDimFixed, # CONFIGID_IDX);
if (inventDimParm.inventSizeIdFlag) inventDimFixed = InventDimFixedClass :: setField (inventDimFixed, # INVENTSIZEID_IDX);
if (inventDimParm.inventColorIdFlag) inventDimFixed = InventDimFixedClass :: setField (inventDimFixed, # INVENTCOLORID_IDX);
return inventDimFixed;
}
View the class declaration you can see:
public class InventDimFixedClass
{
InventDimParm inventDimParm;
# DEFINE.INVENTLOCATIONID_IDX (0)
# DEFINE.BATCH_IDX ??(1)
# DEFINE.LOCATION_IDX (2)
# DEFINE.PALLET_IDX (3)
# DEFINE.SERIALID_IDX (4)
# DEFINE.CONFIGID_IDX (5)
# DEFINE.INVENTSIZEID_IDX (6)
# DEFINE.INVENTCOLORID_IDX (7)
/ / Indexes 0 .. 15 reserved for the SYS layer
/ / Indexes 16 .. 30 reserved for distributors, vars and customers
# INVENTDIMDEVELOP
}
SetField performed:
static InventDimFixed setField (InventDimFixed inventDimFixed, Integer idx)
{
;
inventDimFixed = InventDimFixed | (1 << idx);
return inventDimFixed;
}
That is, with the 1-bit or a result.
Continue to look at the code:
InventQty dateOnHandPhysical (InventDim _inventDim)
{
InventDimParm _inventDimParm;
;
/ / Lower sentence based on previous inventDim construct a _InventDimParm of
_inventDimParm.initFromInventDim (_inventDim);
_inventDimParm = InventDimParm :: orParms (_inventDimParm, InventJournalTable :: journalId2inventDimParm (inventJournalTrans.JournalId));
return InventSumDatePhysicalDim :: onHandQty (inventJournalTrans.TransDate, inventJournalTrans.ItemId, _inventDim, _inventDimParm);
}
Two inventDimParm by bit or get a inventDimParm of, and then use the Enter dates onHandQty starta dimension materials knot stock:
server static InventQty onHandQty (
TransDate _transDate
ItemId _itemId
InventDim _inventDim
InventDimParm _inventDimParm
)
{
InventSumDatePhysicalDim inventSumDatePhysicalDim = InventSumDatePhysicalDim :: newParameters (_transDate, _itemId, _inventDim, _inventDimParm);
;
the return inventSumDatePhysicalDim.postedQty () +
inventSumDatePhysicalDim.receivedQty () -
inventSumDatePhysicalDim.deductedQty () -
inventSumDatePhysicalDim.pickedQty () +
inventSumDatePhysicalDim.registeredQty ();
}
To construct a class InventSumDatePhysicalDim to calculate balances.
Final first InventSumDatePhysicalDim selectInventTransPicked selectInventTransPostingFinancial selectInventTransPostingPhysical selectInventTransRegistered
These four methods will be combined with the two macro statements to query the transaction records the various date is greater than the selected dates, stock from the InventSum table query to the current node, then the middle of the current date and query date the number of transactions according to the actual access to addition and subtraction, the The Query Date junction stock.
These two macros: # InventDimSelect,
# InventDimExistsJoin:
exists join tableId from% 2
where (% 2.InventDimId == 1) &&
(% 2.ConfigId ==% 3.ConfigId | |!% 4.ConfigIdFlag of) &&
(% 2.InventSizeId ==% 3.InventSizeId | |!% 4.InventSizeIdFlag of) &&
(% 2.InventColorId ==% 3.InventColorId | |!% 4.InventColorIdFlag of) &&
(% 2.InventLocationId ==% 3.InventLocationId | |!% 4.InventLocationIdFlag of) &&
(% 2.InventBatchId ==% 3.InventBatchId | |!% 4.InventBatchIdFlag of) &&
(% 2.WMSLocationId ==% 3.WMSLocationId | |!% 4.WMSLocationIdFlag of) &&
(% 2.WMSPalletId ==% 3.WMSPalletId | |!% 4.WMSPalletIdFlag of) &&
(% 2.InventSerialId ==% 3.InventSerialId | |!% 4.InventSerialIdFlag of)
# InventDimDevelop
This macro realized: If you choose a certain dimension, then it must be with you to your dimensions to match the dimension table in the database to find the corresponding data if you do not choose this dimension, this dimension all match.
Finally, we talk about how to use it:
An example:
If you want to query material B-Pack1 dimensions: Warehouse: GW, SIZE: 5, Color: red 4/22/2008junction stock
Can do:
InventDim inventDim;
InventDimParm _inventDimParm;
Date _date;
ItemId itemId;
;
inventDim.inventColorId = "red";
inventDim.inventSizeId = 5;
inventDim.inventLocationId = "gw";
_inventDimParm.initFromInventDim (_inventDim);
_date = 22/4/2008;
itemId = "b-pack1";
return InventSumDatePhysicalDim :: onHandQty (_date, iItemId, inventDim, _inventDimParm);
Inventory of the materials to teach you how to query a date certain combination of dimensions的更多相关文章
- 11.Query an Array of Embedded Documents-官方文档摘录
总结 1.插入数据 db.inventory.insertMany( [ { item: "journal", instock: [ { warehouse: "A&qu ...
- 9.Query on Embedded/Nested Documents-官方文档摘录
1.插入案例 db.inventory.insertMany( [ { item: "journal", qty: 25, size: { h: 14, w: 21, uom: & ...
- 8.Query Documents-官方文档摘录
总结 1 先插入数据 db.inventory.insertMany([ { item: "journal", qty: 25, size: { h: 14, w: 21, uom ...
- Mongo使用
在用mongo进行查询时,$exists表示是否document是否包括这个field,即使field的value为null也算是包括. $exists Syntax: { field: { $exi ...
- spring jdbcTemplate query 返回值为null
spring jdbcTemplate query 返回值为null 今天使用以下方法从数据库中查询数据,返回列表 public List<BookBean> getBooks(){ St ...
- VUE自定义(有限)库存日历插件
开发过程中遇到一个令人发指的,一个element-ui无法满足的日历需求, 改造其日历插件的代价太大,于是索性自己手写一个,需求如下: 1. 根据开始.结束时间计算时间覆盖的月份,渲染有限的可选择日期 ...
- Mongodb的基本使用及对接多数据源
mongodb介绍 MongoDB(来自于英文单词"Humongous",中文含义为"庞大")是可以应用于各种规模的企业.各个行业以及各类应用程序的开源数据库. ...
- 《Ansible权威指南》笔记(2)——Inventory配置
四.Inventory配置ansible通过Inventory来定义主机和组,使用时通过-i指定读取,默认/etc/ansible/hosts.可以存在多个Inventory,支持动态生成.1.定义主 ...
- [转]Teach Yourself Programming in Ten Years——用十年教会自己编程
作者:Peter Norvig 译者:刘海粟 本文原文为:http://norvig.com/21-days.html 该翻译文档的PDF版可以在这里获得:http://download.csdn.n ...
随机推荐
- ZooKeeper 3.5.0 分布式配置问题
ZooKeeper 3.5.0 分布式配置好后,执行./zkServer.sh start 命令启动,报如下错误: 2015-07-02 21:06:01,671 [myid:] - INFO [ma ...
- [OpenGL] 2、企业版VC6.0自带的Win32-OpenGL工程浅析
一. 建立工程 O(∩_∩)O~上一节介绍了一种非常容易的OpenGL的搭建方法,这一节将就上一节介绍的VC6.0企业版自带的OpenGL Win32 Application建立一个模板工程,并分析这 ...
- 找出字符串中第一个不重复的字符(JavaScript实现)
如题~ 此算法仅供参考,小菜基本不懂高深的算法,只能用最朴实的思想去表达. //找出字符串中第一个不重复的字符 // firstUniqueChar("vdctdvc"); --& ...
- Atitit.java c++指针使用总结O7
Atitit.java c++指针使用总结O7 1. 指针的本质 1 2. 指针的作用 1 1. 提升性能问题这常常用于遍历数组, 1 2. 计算两个指针的的距离 2 3. 避免栈溢出,创建动态数据结 ...
- paip.广告过滤系统 php 实现
paip.广告过滤系统 php 实现 作者Attilax 艾龙, EMAIL:1466519819@qq.com 来源:attilax的专栏 地址:http://blog.csdn.net/at ...
- SHINY-SERVER R(sparkR)语言web解决方案 架设shiny服务器
1. shiny server简介 shiny-server是一种可用把R 语言以web形式展示的服务,其实RStudio公司自己构建了R Shiny Application运行的平台(http:// ...
- iOS开发——高级技术&GameCenter服务
GameCenter服务 Game Center是由苹果发布的在线多人游戏社交网络,通过它游戏玩家可以邀请好友进行多人游戏,它也会记录玩家的成绩并在排行榜中展示,同时玩家每经过一定 的阶段会获得不同的 ...
- iOS-UIViewController视图控制器跳转界面的几种常用方法
一.最普通的视图控制器UIViewContoller 一个普通的视图控制器一般只有模态跳转的功能(ipad我不了解除外,这里只说iPhone),这个方法是所有视图控制器对象都可以用的,而实现这种功能, ...
- Liferay7 BPM门户开发之27: MVC Portlet插件工程开发
官网上的教材说实话实在精简不清晰. https://dev.liferay.com/develop/tutorials/-/knowledge_base/7-0/creating-an-mvc-por ...
- IIS7显示ASP的详细错误信息到浏览器
服务端环境:Windows2008 + IIS7 客户端浏览器设置:取消“显示友好的HTTP错误信息” IIS7设置(GUI): 1. 网站->ASP->调试属性->将错误发送到浏览 ...