快乐的昕的电脑
2025-10-17 314c77a2018f3337d0a78f7a24a2e3be10bf60a2
Services/WomdaaManager.cs
@@ -1,6 +1,7 @@
using PadApplication.DB;
using PadApplication.Entites.DbModels;
using PadApplication.Entites.Dto;
using SqlSugar;
namespace PadApplication.Services;
@@ -24,12 +25,6 @@
            list = list.Where(p => p.Daa018 != null && query.OrderStatus.Contains(p.Daa018)).ToList();
        }
        //// 分组逻辑(如需分组,按刀具ID分组取第一条)
        //var vOrders = list.GroupBy(p => p.cutterId)
        //    .Select(g => g.First()).ToList();
        //return vOrders;
        // 如需分组可加分组逻辑,否则直接返回
        return list;
    }
@@ -165,35 +160,123 @@
        VOrdrerBycl.wjQty = VOrdrerBycl.Daa008 - VOrdrerBycl.Daa011;
        //DevMachine
        var devMachine = Db.Queryable<DevMacBycl>()
            .Where(s => s.MachineNo == VOrdrerBycl.MachineNo)
            .First();
        var sql = string.Format(
            "select FINAL_RESULT from MES_EQ_SPOT_CHECKS where department_no = 'XS0101' and EQ_NO = '{0}' and substr(SUBMIT_DATE, 1, 10) = to_char(sysdate, 'yyyy-mm-dd')",
            devMachine.UniqueBarcode);
        var sqlQuerySingle = Db.Ado.SqlQuerySingle<string>(sql);
        VOrdrerBycl.finalResult = sqlQuerySingle;
        // 修复后(确保类型一致,避免参数绑定错误,并防止ID为null时异常)
        var numericalQuery = Db.Queryable<MesNumericalBycl>()
            .Where(n => n.MachineNo == VOrdrerBycl.MachineNo
                        && n.OrderId == (VOrdrerBycl.ID == null ? 0 : VOrdrerBycl.ID)
                        && n.CjNum != null);
        // 开工采集值=第一条记录(按ID最小)
        var startCjNum = numericalQuery
            .OrderBy(n => n.Id)
            .Select(n => n.CjNum)
            .First();
        // 最大采集数(累计当前值)
        var maxCjNum = numericalQuery.Max(n => n.CjNum);
        // 达到最大值的第一次时间(如需展示可后续新增字段)
        var firstReachMaxTime = numericalQuery
            .Where(n => n.CjNum == maxCjNum)
            .OrderBy(n => n.Id)
            .Select(n => n.CjTiem)
            .First();
        // 达到最大值的最后一次时间(若需要判断是否仍在增长,可对比 first 与 last)
        var lastReachMaxTime = numericalQuery
            .Where(n => n.CjNum == maxCjNum)
            .OrderBy(n => n.Id, OrderByType.Desc)
            .Select(n => n.CjTiem)
            .First();
        // 赋值(CurrentCjNum 采用累计最大值,避免 plateau 重复记录导致误解)
        VOrdrerBycl.StartCjNum = startCjNum ?? 0;
        VOrdrerBycl.CurrentCjNum = maxCjNum ?? 0;
        return VOrdrerBycl;
    }
    /// <summary>
    ///     根据工单ID获取打印信息
    ///     根据工单ID获取报工信息
    /// </summary>
    /// <param name="query">包含工单ID的查询条件</param>
    /// <returns>工单打印信息</returns>
    /// <returns>工单报工信息</returns>
    public VPrint GetWomdaaPrintById(OrderMachineDto query)
    {
        var vPrint = Db.Queryable<VPrint>()
            .Where(s => s.Id == query.OrderId).First();
        vPrint.RmiPrQty =
            (int)Math.Ceiling(
                (double)((vPrint.Bqty - vPrint.SQuantity) / vPrint.Qqty));
            .Where(s => s.Id == query.OrderId)
            .First();
        if (vPrint == null)
            return null;
        // 防止除零和空值异常
        var bqty = vPrint.Bqty ?? 0;
        var sQuantity = vPrint.SQuantity ?? 0;
        var qqty = vPrint.Qqty ?? 0;
        if (qqty == 0)
        {
            vPrint.RmiPrQty = 0;
        }
        else
        {
            // 剩余可打印张数 = (可打印总数量 - 已打印数量) / 标准包装数,向上取整
            var remain = bqty - sQuantity;
            vPrint.RmiPrQty = remain > 0 ? (int)Math.Ceiling((double)remain / (double)qqty) : 0;
        }
        return vPrint;
    }
    public (List<MesReportingBgDto> tbBillList, int totalCount) GetByBillNoBG(
        string billNo, string machineNo, DateTime? from, DateTime? to, int pageIndex, int pageSize)
    {
        var query = Db.Queryable<MesReporting>()
            // 关联员工信息表,使用报工人编码匹配员工编码
            .LeftJoin<MesStaff>((r, s) => r.BgPerson == s.StaffNo)
            .Where((r, s) => r.BillNo == billNo);
        if (!string.IsNullOrWhiteSpace(machineNo))
            query = query.Where((r, s) => r.MachineNo == machineNo);
        if (from.HasValue)
            query = query.Where((r, s) => r.BgDate >= from.Value);
        if (to.HasValue)
            query = query.Where((r, s) => r.BgDate < to.Value.AddDays(1));
        var totalCount = query.Count();
        var tbBillList = query.OrderBy((r, s) => r.BgDate, OrderByType.Desc)
            .Select((r, s) => new MesReportingBgDto
            {
                Id = (long)r.Id,
                BillNo = r.BillNo,
                ItemNo = r.ItemNo,
                MachineNo = r.MachineNo,
                StaffNo = r.BgPerson,//报工人编号
                StaffName = SqlFunc.IsNullOrEmpty(s.StaffName) ? r.BgPerson : s.StaffName, // 如有独立姓名字段可替换
                BgDate = r.BgDate,//报工时间
                CsQty = SqlFunc.ToInt32(r.CsQty),//初始采集数
                CjQty = SqlFunc.ToInt32(r.CjQty),//报工时采集数
                BfQty = SqlFunc.ToInt32(r.BfQty),//不良数量
                OkQty = SqlFunc.ToInt32(r.OkQty)//良品数量
            })
            .ToPageList((pageIndex < 1 ? 1 : pageIndex),
                (pageSize < 1 ? 200 : (pageSize > 1000 ? 1000 : pageSize)), ref totalCount);
        return (tbBillList, totalCount);
    }
}