记录一个问题

问题描述

如果一个物料既在A总成零件号下计算为托盘库,在B总成零件号下计算为箱库,则放于箱库。
A中选择排名第21的递补进托盘库。(也需要判断递补的是否在其他总成零件中为箱库,是的话继续递补+判断)

解决思路

为了处理这个问题,我们需要设计一个逻辑流程来确保物料在总成零件号之间的库存计算是正确的。以下是一个可能的逻辑流程来解决这个问题:

  1. 数据准备:
  • 准备一个包含物料、总成零件号、库存类型和库存排名的数据库或数据表。
  • 确保每个物料在不同总成零件号下的库存类型和排名都有记录。
  1. 逻辑判断:
  • 对于每个物料,首先检查其在A总成零件号下的库存类型。
  • 如果物料在A总成零件号下是托盘库,并且没有在B总成零件号下作为箱库存在,则将其放入托盘库。
  • 如果物料在A总成零件号下不是托盘库,或者在B总成零件号下是箱库,则进入递补流程。
  1. 递补流程:
  • 在A总成零件号下,找到排名比当前物料高的所有物料。
  • 检查这些物料的库存类型,确保它们当前在托盘库中。
  • 如果某个物料的库存类型不是托盘库(可能是箱库或其他),则跳过该物料,继续检查下一个。
  • 如果找到了一个符合条件的物料(即在托盘库中,且排名比当前物料高),则将该物料移出托盘库,并将当前物料递补进托盘库。
  • 如果遍历完所有排名更高的物料都没有找到合适的递补物料,则继续向下查找,直到找到排名第21的物料(或其他指定排名的物料)。
  • 对排名第21的物料进行同样的检查:如果它在其他总成零件号下是箱库,则继续向下递补,直到找到一个合适的物料。
  1. 执行操作:
  • 根据逻辑判断的结果,更新数据库或数据表中物料的库存类型和位置。
  1. 错误处理和异常检查:
  • 在整个流程中,添加适当的错误处理和异常检查机制,以确保数据的完整性和准确性。
    例如,检查是否存在重复物料、缺失数据或逻辑错误等。
  1. 性能优化:
  • 如果数据量很大,考虑使用索引来加速查询过程。
  • 优化数据库查询语句,减少不必要的计算和数据传输。
  1. 测试和验证:
  • 在实际部署之前,对逻辑流程进行充分的测试和验证,确保它能够正确处理各种情况并产生准确的结果。
    请注意,以上流程是一个高级概述,具体的实现细节可能会因数据库结构、编程语言和业务需求而有所不同。在实际应用中,你可能需要根据具体情况进行调整和优化。

实现

在C#中实现上述逻辑,你需要定义一些数据结构来存储物料、总成零件号、库存类型、排名等信息,然后编写相应的逻辑来处理这些数据。以下是一个简化的示例代码,展示了如何实现这一逻辑:

首先,定义一些类来表示物料、总成零件和库存信息:

public class Material  
{  
    public string Id { get; set; }  
    public Dictionary<string, InventoryInfo> Inventories { get; set; }  
  
    public Material()  
    {  
        Inventories = new Dictionary<string, InventoryInfo>();  
    }  
}  
  
public class InventoryInfo  
{  
    public string AssemblyPartNumber { get; set; }  
    public InventoryType InventoryType { get; set; }  
    public int Rank { get; set; }  
}  
  
public enum InventoryType  
{  
    Pallet,  
    Box,  
    // 可以添加其他库存类型  
}  
  
public class InventoryManager  
{  
    private List<Material> materials;  
  
    public InventoryManager()  
    {  
        materials = new List<Material>();  
        // 初始化物料数据,这里仅作为示例  
        var material = new Material  
        {  
            Id = "Material1",  
            Inventories = new Dictionary<string, InventoryInfo>  
            {  
                { "A", new InventoryInfo { AssemblyPartNumber = "A", InventoryType = InventoryType.Pallet, Rank = 20 } },  
                { "B", new InventoryInfo { AssemblyPartNumber = "B", InventoryType = InventoryType.Box, Rank = 10 } },  
                // ... 其他总成零件号的库存信息  
            }  
        };  
        materials.Add(material);  
        // 可以添加更多物料  
    }  
  
    public void ProcessMaterials()  
    {  
        foreach (var material in materials)  
        {  
            // 检查A总成零件号下的库存类型  
            if (material.Inventories.TryGetValue("A", out var inventoryA) && inventoryA.InventoryType == InventoryType.Pallet)  
            {  
                // 检查B总成零件号下的库存类型  
                if (!material.Inventories.TryGetValue("B", out var inventoryB) || inventoryB.InventoryType != InventoryType.Box)  
                {  
                    // 物料可以放入托盘库(这里只是打印信息,实际中可以执行放入操作)  
                    Console.WriteLine($"Material {material.Id} can be placed in pallet.");  
                }  
                else  
                {  
                    // 需要递补进托盘库  
                    var alternateMaterial = FindAlternateMaterialForPallet(material.Id, "A");  
                    if (alternateMaterial != null)  
                    {  
                        // 执行递补逻辑(这里只是打印信息)  
                        Console.WriteLine($"Material {alternateMaterial.Id} is promoted to pallet for {material.Id}.");  
                    }  
                }  
            }  
        }  
    }  
  
    private Material FindAlternateMaterialForPallet(string originalMaterialId, string assemblyPartNumber)  
    {  
        // 这里简化逻辑,只查找排名第21的物料(假设排名是唯一的)  
        foreach (var material in materials)  
        {  
            if (material.Inventories.TryGetValue(assemblyPartNumber, out var inventory) && inventory.Rank == 21)  
            {  
                // 检查该物料是否在其他总成零件中为箱库  
                if (!material.Inventories.Values.Any(i => i.InventoryType == InventoryType.Box && i.AssemblyPartNumber != assemblyPartNumber))  
                {  
                    return material;  
                }  
            }  
        }  
        return null; // 没有找到合适的递补物料  
    }  
}

请注意,上述代码是一个简化的示例,它假设你已经有了物料的库存信息,并且这些信息存储在一个Material类的实例列表中。ProcessMaterials方法遍历所有物料,并根据提供的逻辑进行处理。FindAlternateMaterialForPallet方法用于查找可以递补进托盘库的物料。

在实际应用中,你可能需要根据实际情况调整数据结构、逻辑和错误处理。此外,如果物料和库存信息存储在数据库中,你需要编写数据库访问代码来获取和更新这些数据。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

重磅!UOSDN焕新,开启创新之旅!

亲爱的开发者们 经过精心打磨和优化 全新改版的UOSDN&#xff08;统信开发者支持网络&#xff09; 已经正式上线啦&#xff01; 我们致力于为您打造一个更加便捷、高效、富有创意和互动性的开发平台&#xff0c;详情&#x1f449;https://uosdn.uniontech.com/ 以UOSDN作为载…

uni-app 微信小程序开发到发布流程

1. uni-app 微信小程序开发到发布流程 1.1. 新建一个uni-app 项目 1.2. 发行微信小程序 1.3. 微信开发者平台的微信小程序appid 复制进来&#xff08;点击发行&#xff09; 1.4. IDE may already started at port xxxx, trying to connect &#xff08;1&#xff09;关闭微信…

ffmpeg编码图象时报错Invalid buffer size, packet size * < expected frame_size *

使用ffmpeg将单个yuv文件编码转为jpg或其他图像格式时&#xff0c;报错&#xff1a; Truncating packet of size 11985408 to 3585 [rawvideo 0x1bd5390] Packet corrupt (stream 0, dts 1). image_3264_2448_0.yuv: corrupt input packet in stream 0 [rawvideo 0x1bd7c60…

借助AI写代码,使用通义灵码智能编写Java和Vue3项目,在Idea和vscode里用AI写代码

在人工智能技术越来越成熟的当下&#xff0c;好多人说AI会取代程序员&#xff0c;这句话石头哥不知可否。但是有一点可以肯定&#xff0c;会熟练使用Ai&#xff0c;驾驭Ai的程序员肯定不会被时代所淘汰。所以今天石头哥就来教大家如何借助Ai来提升自己的代码编写效率。 一&…

时序(流式)图谱数据仓库AbutionGraph功能介绍-Streaming Graph OLAM Database

AbutionGraph是一款端到端的流式数据实时分析的图谱数据库&#xff0c;实时&#xff08;流式写入实时、高QPS决策分析实时、流式预处理实时&#xff09;表现在&#xff1a; 构建实时查询QPS响应时长与历史数据量无关的图模型&#xff1b;接入流式数据并实时更新图计算指标&…

java和网络安全,哪个就业前景更大?

常年以来&#xff0c;Java一直占据着程序语言的前三名&#xff0c;因此也就成了许多进入IT行业的首选语言。但随着5G时代的兴起&#xff0c;网络安全也成了当今最火热的“风口行业”。导致很多年轻人不知如何选择&#xff0c;一直处于纠结徘徊的状态。下面盾叔就带大家了解一下…

【Qt】QMessageBox 各种对话框的默认显示效果

1. 函数原型 void about(QWidget *parent, const QString &title, const QString &text)void aboutQt(QWidget *parent, const QString &title QString())QMessageBox::StandardButton critical(QWidget *parent, const QString &title, const QString &…

SpringBoot-SpringBoot整合Swagger使用教程(图文介绍,一篇就够了)

前言 日常开发中&#xff0c;接口都是和开发文档相结合的。不论是和前端对接还是三方对接亦或者是接口留档&#xff0c;当我们开发完接口后&#xff0c;都需要去创建对应的接口文档。而修改接口后也要修改相对应的接口文档&#xff0c;但是这个真的很容易疏漏。而且相对于繁重的…

用数组模拟栈实现递归函数模拟

做算法课设时候看到题目要求模拟函数递归时候栈的入栈出栈过程。本来想着直接调用系统递归函数即可&#xff0c;可是发现系统函数栈的空间非常小大约只有3000层&#xff0c;很容易爆栈。于是便有了用栈去模拟递归函数的想法&#xff0c;但是上网查了下貌似相关代码比较少&#…

cartographer从入门到精通(一):cartographer介绍

一、cartographer重要文档 有关cartographer的资料有2个比较重要的网站&#xff0c;我们的介绍也是基于这两个网站&#xff0c;其中会加入自己的一些理解&#xff0c;后续也有一些对代码的修改&#xff0c;来实现我们想完善的功能。 1-Cartographer 2-Cartographer ROS 第1个…

如何使用飞书快捷指令无感记账,ios版

总结 很多人无法长期坚持记账&#xff0c;主要是每次消费需要打开手机软件&#xff0c;一系列繁琐的操作&#xff0c;导致过程中可能就忘了。 今天给大家带来飞书自动记账。 演示视频 点击查看&#xff1a;https://www.douyin.com/video/7312857946382241063 安装 下载快捷…

【java计算机毕设】网上商城系统java MySQL ssm vue html maven项目设计代码源码+文档PPT

1项目功能 2项目介绍 系统功能&#xff1a; 网上商城系统包括管理员、用户俩种角色。 管理员功能包括个人中心模块用于修改个人信息和密码、管理员管理、基础数据管理、论坛管理、商品管理、浏览记录管理、公告信息管理、用户管理、轮播图信息。 用户功能包括个人中心模块用于…

【Pyspark-驯化】spark中高效保存数据到hive表中:stored as PARQUET

【Pyspark-驯化】spark中高效保存数据到hive表中&#xff1a;stored as PARQUET 本次修炼方法请往下查看 &#x1f308; 欢迎莅临我的个人主页 &#x1f448;这里是我工作、学习、实践 IT领域、真诚分享 踩坑集合&#xff0c;智慧小天地&#xff01; &#x1f387; 免费获取相关…

python数据分析与可视化一

公共部分 # 引入数据分析工具 Pandas import pandas as pd # 引入数据可视化工具 Matplotlib import matplotlib.pyplot as plt # 引入数据可视化工具 Seaborn (基于matplotlib) import seaborn as sns # 解决输出时的列名对齐问题 pd.set_option(display.unicode.east_…

短视频利器 ffmpeg (2)

ffmpeg 官网这样写到 Converting video and audio has never been so easy. 如何轻松简单的使用&#xff1a; 1、下载 官网&#xff1a;http://www.ffmpeg.org 安装参考文档&#xff1a; https://blog.csdn.net/qq_36765018/article/details/139067654 2、安装 # 启用RPM …

华强盛网络变压器外部电路如何接线

图一是 华强盛 Hqst 网络变压器工厂19926430038 华强盛电子导读&#xff1a; 网络变压器的外部电路接线通常依赖于其设计和用途。一般来说&#xff0c;网络变压器有多个端口&#xff0c;每个端口可能用于不同的连接或功能。以下是一些可能的接线方式&#xff1a; 1. **主电源…

自研网关架构设计

网关项目 1. 了解网关网关横向对比为什么自研网关 2. 架构设计技术栈技术要点异步化设计使用缓存缓冲合理使用串行化吞吐量为王合适的工作线程 架构图 1. 了解网关 概念 访问数据、业务逻辑或功能的 “前门”负责处理接受和处理调用过程中的所有任务 类型 RESTful APl 使用…

核方法总结(三)———核主成分(kernel PCA)学习笔记

一、核主成分 1.1 和PCA的区别 PCA &#xff08;主成分分析&#xff09;对应一个线性高斯模型&#xff08;参考书的第二章&#xff09;&#xff0c;其基本假设是数据由一个符合正态分布的隐变量通过一个线性映射得到&#xff0c;因此可很好描述符合高斯分布的数据。然而在很多实…

深入分析 Android BroadcastReceiver (七)

文章目录 深入分析 Android BroadcastReceiver (七)1. 高级应用场景1.1 示例&#xff1a;动态权限请求1.2 示例&#xff1a;应用内通知更新 2. 安全性与性能优化2.1 示例&#xff1a;设置权限防止广播攻击2.2 示例&#xff1a;使用 LocalBroadcastManager2.3 示例&#xff1a;在…

零成本打造精品宣传册

​随着互联网的发展&#xff0c;企业和个人对宣传册的需求日益增长&#xff0c;然而&#xff0c;高质量的宣传册制作往往需要不菲的成本。那么&#xff0c;如何零成本打造精品宣传册呢&#xff1f; 一、明确定位和目标群体 在制作宣传册之前&#xff0c;首先要明确其定位和目标…