Oracle寄售功能 价格客制化

%ignore_a_1%: 用Oracle R12的寄售功能的时候,碰到了一个很麻烦的问题:价格抓取的问题。 由于这个问题导致寄售功能在公司一直用不好,库存报表基本都需要他们人工出(自己算每个月每种价格的产品的进出存)。 请教了别的公司的EBS同事,加上自己的实际解决逻辑的考

前言:

用Oracle R12的寄售功能的时候,碰到了一个很麻烦的问题:价格抓取的问题。

由于这个问题导致寄售功能在公司一直用不好,库存报表基本都需要他们人工出(自己算每个月每种价格的产品的进出存)。

请教了别的公司的EBS同事,加上自己的实际解决逻辑的考虑,终于都将问题给解决了,现在总结一下解决的思路,有类似需求的朋友可以参考一下。

由于机密性的考虑,开发的源代码就不共享了,希望理解哈。

一、问题提出

首先,对标准的寄售功能大概说明:

下一揽子PO(BPA)à下标准POà标准PO接收入库à领料等动作(消耗供应商库存)à所有权转移(转移的单价取BPA的(分段)价格)à产生应付(应付的价格取BPA的价格)

标准的寄售功能不能满足的核心问题点:

标准的寄售功能,做消耗的时候,价格都是抓一揽子PO(BPA)行的价格。而实际上,业务部门希望做消耗的时候,抓的价格应该是实际入库的标准PO行的价格(每次接收都是不一样的价格,这样子更加合理)。

同理,传到应付的价格也应该是标准PO行的价格。

就这个价格的问题,需要客制化。

二、问题分析和解决

(一)  客制化逻辑:

核心逻辑是料号启用批次管理,每次接收入库都新增一个批次,这个批次就是从头到尾跟踪物料消耗价格的依据。

举个例子:

料号A下了一揽子PO:BPA1,行价格是1元。

接着料号A用标准PO:SPO1,行价格是1.2元,入库入1000个,批次LOT001。

然后料号A用标准PO:SPO2,行价格是1.5元,入库入2000个,批次LOT002。

如果是直接用标准的寄售功能,在料号A消耗的时候,做所有权转移等物料事务处理的价格都是1元。

应收的价格也是1元。

客制修改后,可以实现的效果:

料号A消耗的时候,因为料号A启用批次管理,则其必须挑选一个消耗的批次。

如果挑选的是批次LOT001,则所有权转移的价格(交易成本)是1.2元,传到应付的价格也是1.2元。

如果挑选的是批次LOT002,则所有权转移的价格(交易成本)是1.5元,传到应付的价格也是1.5元。

不同的入库批次,消耗的价格是完全可以分开的。

(二)  程序实现过程:

主要的开发点是要修改系统在做杂发(或者库存转移)的时候,需要针对消耗寄售的库存部分做定制修改。

大概过程:

例如User是做杂发领料。

1每过账一行(准备做交易的时候),先判断该行是否一定走寄售的流程(是否会自动发生所有权转移)。

由于,料号A的库存,在杂发画面是供应商库存和本公司库存是混合在一起了,按照优先消耗本公司库存的严则,所以要首先判断是否是完全属于寄售的库存的交易,或者完全属于XYG库存的交易。

举个例子,物料A,库存共有5000个;其中本公司库存2000个,供应商库存3000个。

如果发料
如果发料>2000个,则提示错误并禁止其发料。如果允许User这样子操作,程序逻辑很难走了,因为寄售的交易的价格是标准PO的价格,而非寄售交易的价格应该是走系统标准成本(我这里用的是移动平均成本)。一笔物料交易不可能有2个成本。

由于交易是按照组织+库别+货位+料号+批次来进行的,一般寄售的物料的库存和本公司的库存都是分开库别的,所以同时一个库别有2种不同类型的库存是很少的。

2上面第一步已经确定了该笔交易是否属于寄售的交易行。

2.1如果不是,则按照普通的交易走,不做任何的特殊处理。

2.2如果是属于寄售的库存的交易,那么系统会自动做所有权转移。所以,这时候要根据标准PO的价格更新BPA价格和交易成本。

1)根据批次找到对应接收的PO的信息(首次接收的)

更新批次表,记录对应的PO行ID。

自动更新接收方式:将发票匹配选项自动更新为接收R。

2)根据Po_Line_ID找到接收PO的价格

3)根据物料ID,供应商ID,供应商地点ID找到对应的一揽子协议的PO(BPA)行,然后直接根据标准的PO行价格更新BPA行价格。

4)强烈建议将上面找的信息记录到一个中间的控制记录表格。

3调用MTL_ONLINE_TRANSACTION_PUB.PROCESS_ONLINE过账对应的领料行。

4如果过账成功,并且是属于寄售的交易行,这时候应该要将寄售行的单价信息更新回去原来的。

按照上面的步骤一步一步来做,基本可以实现User的目的。

财务方面:

因为做的寄售杂发交易的单价(包括自动产生的所有权转移的交易行价格),都是标准接收PO的单价。

传到应付里面的价格也是标准接收PO的单价。

为了让User方便操作,AP标准的发票匹配画面我也做了一定的客制化。

主要的修改是,匹配画面的默认匹配数量=对应接收编号的PO行的消耗数量-已经开票的数量。

(标准的是,对应接收编码的PO行接收的数量-已经开票的数量)

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1043591.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
魔秀桌面主题设置教程
上一篇 2025年12月2日 05:42:41
苹果 iOS 18 / macOS 15 升级 Safari 浏览器:可 AI 生成网页摘要、帮你规划出游等
下一篇 2025年12月2日 05:42:43

相关推荐

  • php实现哪些功能

    PHP是一种通用脚本语言,可用来实现广泛的功能,包括:动态Web开发:生成响应用户请求的动态 веб页面。内容管理系统(CMS):构建允许用户管理网站内容的CMS。电子商务:开发具有购物车、订单处理和支付网关集成的电子商务网站。服务器端编程:编写命令行脚本和工具。文件操作:创建、读取、写入和删除文件…

    2026年5月10日
    000
  • JavaScript输入字段长度验证指南

    JavaScript输入字段长度验证指南JavaScript输入字段长度验证指南JavaScript输入字段长度验证指南JavaScript输入字段长度验证指南

    本文详细介绍了在%ignore_a_1%中正确获取html输入字段字符长度并进行有效验证的方法。我们将重点解析常见的错误,即直接对dom元素使用`length`属性,并演示如何通过访问`value`属性来获取实际的字符串长度。同时,文章还将探讨html `maxlength`属性与javascrip…

    2026年5月10日 用户投稿
    000
  • SQL查询:精确判断事件过期,结合日期与时间列

    本文旨在解决数据库中事件过期判断不精确的问题,特别是当事件的过期日期和时间分别存储在不同列时。我们将探讨两种主流的sql查询策略:一种是利用逻辑运算符`or`和`and`进行分情况判断,另一种是通过合并日期和时间列为单一时间戳进行直接比较。文章将详细阐述每种方法的实现方式、适用场景及相关注意事项,确…

    2026年5月10日
    200
  • HTML表单如何实现白名单功能?怎样只允许授权用户?

    要实现%ignore_a_1%的白名单功能并确保只有授权用户操作,核心答案是必须依赖后端服务器进行严格的身份认证、会话管理、授权检查和数据验证,前端仅能提供用户体验层面的初步提示而不能保障安全;具体而言,首先通过用户身份认证(如用户名/密码或oauth)确认用户身份,服务器创建会话并返回标识符,后续…

    2026年5月10日
    800
  • 如何用C#实现数据库的跨平台迁移?使用EF Core工具?

    使用EF Core实现跨平台数据库迁移,需定义实体与DbContext,通过动态配置不同数据库提供程序,利用EF Core CLI生成并应用迁移,结合Fluent API处理数据库差异,确保结构与数据兼容。 要实现数据库的跨平台迁移,C# 中最常用且高效的方式是使用 Entity Framework…

    2026年5月10日
    000
  • Python连接MySQL 5.1:克服旧版认证与字符集兼容性挑战

    本教程详细阐述了如何使用Python 3和mysql.connector库成功连接到老旧的MySQL 5.1数据库。文章重点介绍了解决旧版认证协议和字符集兼容性问题的关键配置,特别是use_pure=True和charset=’utf8’的重要性,并提供了可运行的代码示例。同…

    2026年5月10日
    000
  • HTML中 table鼠标拖拽排序功能的实现

     table是html里不可缺少的一项属性,很多地方我们都要用到,本文主要介绍了html table鼠标拖拽排序功能的相关资料,需要的朋友可以参考下,希望可以帮助到大家。 效果图: 1.引入文件 2.给元素附上sortable类 立即学习“前端免费学习笔记(深入)”; 3.开启并配置 $(funct…

    2026年5月10日
    000
  • 想提升IT技能?哪些含金量高的认证值得考?

    it职业发展:高含金量认证助您成功 想在IT领域提升竞争力?选择合适的认证至关重要。本文推荐几项国内外认可度高的IT认证,助您在职业道路上更进一步。 热门认证推荐: 1. 高级软件设计师(软考高级): 国内IT领域含金量最高的认证之一。涵盖软件工程、项目管理及计算机基础知识。证明您在软件设计和开发方…

    2026年5月10日
    000
  • 什么是资产代币化(Asset Tokenization)?它如何将现实世界资产带入区块链?

    资产代币化是通过区块链将房产、股票等实体资产权益转化为可分割的数字代币。首先选择目标资产并由合规机构确权估值,随后在链上发行对应代币并通过智能合约绑定权益比例,实现自动化分红与转让。为确保真实性,引入第三方审计和去中心化预言机同步链下数据,资金流由托管账户与链上地址联动记录,提升透明度。代币化降低投…

    2026年5月10日
    000
  • MySQL、PostgreSQL、SQL Server和Oracle中空字符串、数字0和NULL占用空间有何区别

    不同数据库系统中空字符串、数字0和NULL的存储空间差异 本文比较了MySQL InnoDB、PostgreSQL、SQL Server和Oracle数据库中,空字符串(”)、数字0和NULL值在磁盘上所占用的空间大小。 MySQL InnoDB存储引擎: 整型字段: NULL: 不占用…

    2026年5月10日
    000
  • html文档中含有java怎么运行_html含java运行方法【教程】

    现代浏览器不支持Java Applet,推荐通过JavaScript调用Java后端服务或使用WebAssembly运行Java代码。 如果您在HTML文档中嵌入了Java代码,但发现无法正常运行,这通常是因为现代浏览器不再支持Java小程序(Applet)或相关插件。以下是几种实现HTML中Jav…

    2026年5月10日
    000
  • php主要运用哪些东西

    PHP 是一种通用脚本语言,主要用于 Web 开发,包括创建动态网页、网站框架和内容管理系统。此外,它还支持 Web 服务(RESTful 和 SOAP)、数据库操作、命令行脚本、桌面应用程序和图像处理。 PHP 语言的主要应用 PHP(超文本预处理器)是一种广泛应用的通用脚本语言,主要用于 Web…

    2026年5月10日
    100
  • jQuery与CSS3动画功能有何不同?优劣对比

    jQuery与CSS3动画功能有何不同?优劣对比 引言: 如今,网页设计已经越来越注重用户体验。而动画效果作为增强用户体验的重要手段之一,在网页设计中扮演着重要角色。在实现动画效果的过程中,开发者面临着选择使用jQuery还是CSS3动画的问题。本文将对两者进行对比分析,探讨其优劣之处,并为读者提供…

    2025年12月24日
    300
  • html如何传送文件_使用HTML表单实现文件上传功能【上传】

    需配置form的method=”post”和enctype=”multipart/form-data”,添加type=”file”输入框并设匹配后端的name属性,可加multiple、accept、required等属性,辅以…

    2025年12月23日
    000
  • java怎么编译运行.html_java编译运行.html方法【教程】

    Java程序的编译运行与HTML无关,需使用JDK。1. 编写HelloWorld.java文件;2. 命令行执行javac HelloWorld.java生成.class文件;3. 执行java HelloWorld运行程序。注意:HTML是网页标记语言,不能直接运行Java代码,勿将二者混淆。确…

    2025年12月23日
    000
  • 怎么运行html的applet小程序_运行html applet小程序步骤【指南】

    现代浏览器已不再默认支持Java Applet,需通过安装JRE、启用插件、使用支持NPAPI的旧版浏览器(如Firefox 52.9 ESR)、调整Java安全级别至中,并将网站添加到例外站点列表方可运行。 如果您在尝试运行HTML中的Applet小程序时遇到问题,可能是因为现代浏览器已不再默认支…

    2025年12月23日
    000
  • html怎么运行css_html与css配合运行步骤【指南】

    首先确认CSS文件是否通过link标签正确引入,检查路径、命名及大小写;其次可使用内部或行内样式测试渲染功能;最后确保在支持静态资源的服务器环境下运行,避免本地打开导致解析失败。 如果您已经编写了HTML和CSS文件,但页面样式没有正确显示,则可能是由于CSS未正确链接或路径配置错误。以下是确保HT…

    2025年12月23日
    000
  • 使用JavaScript实现HTML元素CSS类的条件判断与动态切换

    本教程详细讲解如何利用JavaScript的classList API对HTML元素的CSS类进行条件判断和动态切换。通过contains()检查现有类,并结合remove()和add()方法,实现根据特定条件在不同样式状态间平滑过渡。文章提供完整示例代码,帮助开发者高效管理页面元素的视觉表现。 在…

    2025年12月23日
    000
  • JavaScript:从子元素中批量移除特定CSS类

    本教程详细介绍了如何使用%ignore_a_1%高效地从父元素下的多个子元素中移除指定的css类。文章首先纠正了常见的操作误区,接着深入讲解了如何结合`document.queryselectorall`和`foreach`方法,配合`classlist.remove()`实现批量类名管理,并演示了…

    2025年12月23日
    000
  • HTML5表单属性怎么用_HTML5placeholderrequired等表单属性的功能与用法

    HTML5新增表单属性提升交互与验证效率:placeholder提供输入提示,required确保必填项,autofocus实现自动聚焦,pattern支持正则校验,autocomplete控制自动填充,multiple允许多值输入,min、max和step限定数值范围,结合使用可减少JavaScr…

    2025年12月23日
    000

发表回复

登录后才能评论
关注微信