白码ERP实现销售订单自动生成生产订单功能

某ERP项目中,业务员创建销售单后,还需要确认产品库存是否充足,如不充足,还需要手动创建生成订单通知车间进行生产,比较麻烦,客户希望系统可以自动进行判断,自动根据现有库存生成生产订单。

目标:

新建销售单时自动根据库存是否充足新建生产订单,缺货数即为生产数;

前期准备:

创建产品、销售单、销售单明细、生产订单、生产订单明细数据表,具体属性如下图(可根据实际需求进行调整),其中销售单明细的“缺货数”用于判断哪些产品库存不足,便于转化生产订单。

创建商品

销售单

销售单明细

生产订单

生产订单明细数据表

实现步骤:

新建一个功能,命名为新建销售单;

①第一步使用新增数据的步骤,新增销售单,其中总金额先不填写,在后续步骤自动合计即可;

新建销售单

合计

②第二步使用新增集合的步骤,新增销售单明细,

新增销售单明细

其中小计需要设为数量×单价,缺货数设为数量 - 产品的库存数;

销售单明细参数

小计

③第三步使用关联获取数据的步骤,获取到第一步新增的销售单,并合计明细的金额;

获取新增订单数据

合计明细金额

④前三步就完成了销售单的创建,接下来就需要根据缺货情况看看是否需要生成生产订单,第三步使用条件判断的步骤,判断第二步的集合中,库存是否充足,即所有的缺货数都小于0;

判断缺货情况

使用判断条件

判断库存

⑤若判断结果为假,即存在产品库存不足的,则需要生成生产,第五步先用获取集合的步骤,获取缺货数大于0的销售单明细,也就获取到了库存不足的产品,若判断为真,则不存在缺货,无需生成生产订单,也就没有后续的步骤了,所以这里的判断步骤只需连接判断为假的路线即可;

判断为假则生产

不需生产

⑥第六步使用新增数据的步骤,新增生产订单;

新增订单

⑦第七步使用新增集合的步骤,根据第五步获取到的缺货明细,进行新增生产订单的明细;

使用新增集合

获取缺货明细

新增生产订单明细

⑧至此,功能已做好,发布到用户测试

显示结果

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/634788.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Pyside6入门教学——编写一个UI界面并显示

1、安装Pyside6 输入下列命令安装Pyside6。 pip install Pyside6 2、设计UI 打开Qt设计工具(在安装Pyside6包的目录下)。 【注】我这用的是anaconda虚拟环境,所以我的路径是D:\App\Anaconda3\envs\snake\Lib\site-packages\PySide6。设计…

三使用Docker Hub管理镜像

使用Docker Hub管理镜像 Docker Hub是Docker官方维护的Docker Registry,上面存放着很多优秀的镜像。不仅如此,Docker Hub还提供认证、工作组结构、工作流工具、构建触发器等工具来简化我们的工作。 前文已经讲过,我们可使用docker search 命…

124 二叉搜索树的后序遍历序列

问题描述:输入一个整数数组,判断该数组是不是某二叉搜索树的后续遍历结果。 递归方式求解:对于后续遍历而言,其顺序是左子节点->右子节点->根节点,而根据二叉搜索树的特点,左子树比根节点小&#xf…

freemaker导出

一、创建ftl模板文件 1、将xls文件转换为xml格式 需要将xml中内容格式化一下, 在线 XML 格式化 | 菜鸟工具 (jyshare.com) 将格式化好的内容,保存在 ftl 文件中,放入项目文件。 二、后端对数据做组装 Java代码中对导出文件做赋值 Override…

k8s之对外服务ingress

一、service 1、service作用 ①集群内部:不断跟踪pod的变化,不断更新endpoint中的pod对象,基于pod的IP地址不断变化的一种服务发现机制(endpoint存储最终对外提供服务的IP地址和端口) ②集群外部:类似负…

c++算法之双指针

目录 双指针简介 对撞指针 求解步骤 例题 蓝桥oj1371回文判定 题目描述 输入描述 输出描述 输入输出样例 示例 1 示例 2 运行限制 解 快慢指针 求解步骤 例题 蓝桥oj1372美丽的区间 题目描述 输入描述 输出描述 输入输出样例 示例 1 运行限制 解 例题 蓝…

Vue3 在 history 模式下通过 vite 打包部署白屏

Vue3 在 history 模式下通过 vite 打包部署后白屏; 起因 hash 模式 url 后面跟个 # 强迫症犯了改成了 history,就此一波拉锯战开始了 ... 期间 nigix 和 router 各种反复排查尝试最终一波三折后可算是成功了 ... Vue官方文档 具体配置可供参考如下: 先简要介绍下,当前项目打包…

【EI会议征稿通知】第七届先进电子材料、计算机与软件工程国际学术会议(AEMCSE 2024)

第七届先进电子材料、计算机与软件工程国际学术会议(AEMCSE 2024) 2024 7th International Conference on Advanced Electronic Materials, Computers and Software Engineering 第七届先进电子材料、计算机与软件工程国际学术会议(AEMCSE 2024)将于2024年5月10-1…

Vue3实现响应式编程

Vue 3的响应式编程实现主要是基于Proxy和Object.defineProperty。以下是对Vue 3的响应式编程实现的简单说明和代码示例。 在Vue 3中,响应式数据是通过使用JavaScript的Proxy对象实现的。Proxy对象可以用来定义基本操作的自定义行为(如属性查找&#xff…

AI智慧导诊系统(源码),利用人工智能技术,通过根据患者症状描述智能推荐挂号科室。

什么是智慧导诊系统? 简单地说,智慧导诊系统是一种利用人工智能技术,为医生提供帮助的系统。它可以通过分析患者的症状和病史为医生提供疾病诊断和治疗方案的建议。 智慧导诊系统可根据患者症状描述智能推荐挂号科室。系统采用对话式询问患者症状&…

侧边栏的伸展与缩放

用到技术栈: vue3viteelement-plus 使用 CSS3 中的 transition 属性来实现平滑过渡效果。可以给 aside 元素添加 transition 属性,来让浏览器自动实现宽度变化的过渡动画 设置过渡时间为 0.3s,结合 will-change 属性进行优化---will-chang…

2024-01-17(SpringCloud)

1.使用openFeign的itemClient接口去做远程调用其他微服务中的接口。但我们直接使用了itemClient接口,而不是该接口的实现类,说明我们是使用该接口的代理对象帮我们做远程调用的。这个代理对象是invocationHandler来生成的。 2.openFeign底层发起远程调用…

什么是DOM?(JavaScript DOM是什么?)

1、DOM简洁 DOM是js中最重要的一部分,没有DOM就不会通过js实现和用户之间的交互。 window是最大的浏览器对象,在它的下面还有很多子对象,我们要学习的DOM就是window对象下面的document对象 DOM(Document Object Model&#xff09…

【数学建模美赛论文word模板更新】数学建模美赛O/F奖论文word写作模板——研赛国赛国一、美赛F/O奖学长联合制作

参加美赛不知道论文如何写、如何排版?快来领取免费模板哦~ 我们的word模板由研赛国赛国一、美赛F/O奖学长联合制作。 论文模板是论文的一部分,它代表着你的论文从构思到完成的全过程,是论文的雏形。 论文模板能够节省你的写作时间&#xf…

深入探讨生产环境中秒杀接口并发量剧增、负载过高的情况该如何应对?

目录 引言 1. 实施限流措施 1.1 令牌桶算法: 1.2 漏桶算法: 1.3 使用限流框架: 2. 优化数据库操作 2.1. 索引优化 2.2. 批量操作减少交互次数: 2.3. 避免全表扫描: 2.4使用InnoDB引擎: 2.5优化事…

力扣59-螺旋矩阵

螺旋矩阵 题目链接 class Solution { public:vector<vector<int>> generateMatrix(int n) {vector<vector<int>>res(n, vector<int>(n, 0));int dx[4] {0, 1, 0, -1}, dy[4] {1, 0, -1, 0}; //方向偏移数组int x 0, y 0; //当前位置for(…

一、可行性研究报告模板(软件工程)

一、可行性研究报告 1&#xff0e;引言 1.1编写目的 1.2项目背景 1.3定义 1.4参考资料 2&#xff0e;可行性研究的前提 2.1要求 2.2目标 2.3条件、假定和限制 2.4可行性研究方法 2.5决定可行性的主要因素 3&#xff0e;对现有系统的分析 3.1处理流程…

设计模式之7大设计原则-Java版

软件设计模式是前辈们代码设计经验的总结&#xff0c;可以反复使用。设计模式共分为3大类&#xff0c;创建者模式(5种)、结构型模式(7种)、行为型模式(11种)&#xff0c;一共23种设计模式&#xff0c;软件设计一般需要满足7大基本原则。下面通过5章的学习一起来看看设计模式的魅…

当MySql有字段为null,索引是否会失效

sql执行过程中,使用is null 或者is not null 理论上都会走索引,由于优化器的原因导致索引失效变成全表扫描,或者说是否使用索引和NULL值本身没有直接关系,和执行成本有关系。 数据行记录如何存储NULL值的&#xff1f; InnoDB 提供了 4 种行格式 Redundant:非紧凑格式,5.0 版…

01.CheckStyle代码检查工具

CheckStyle代码检查工具 1.介绍 Checkstyle 是一种开发工具&#xff0c;可帮助程序员编写符合编码标准的 Java 代码。它使检查 Java 代码的过程自动化&#xff0c;从而使开发者免于完成这项无聊&#xff08;但重要&#xff09;的任务。这使得它非常适合想要强制执行编码标准的…