111
啊鑫
2025-09-04 8d771316d68f1523bcdf30c97d3a55107cb5ae56
MES.Service/service/BasicData/MesItemTypeManager.cs
@@ -15,9 +15,10 @@
        {
            switch (customer.Type)
            {
                case "0":
                case "2":
                case "4":
                    return InsertItemType(entity);
                case "1":
                case "3":
                    return DeleteItemType(entity.Id);
                default:
                    throw new ArgumentNullException(
@@ -50,7 +51,7 @@
        throw new NotImplementedException("插入失败");
    }
    private bool DeleteItemType(long? id)
    private bool DeleteItemType(decimal? id)
    {
        var deleteById = Db.Deleteable<MesItemType>()
            .Where(it => it.Id == id).ExecuteCommand();
@@ -64,9 +65,9 @@
    {
        var entity = new MesItemType
        {
            Id = string.IsNullOrEmpty(department.Id)
                ? DateTimeOffset.UtcNow.ToUnixTimeSeconds()
                : long.Parse(department.Id),
            // Id = string.IsNullOrEmpty(department.Id)
            //     ? DateTimeOffset.UtcNow.ToUnixTimeSeconds()
            //     : long.Parse(department.Id),
            Pgroup = department.FParentId,
            Tcode = department.FNumber,
            Tname = department.FName,
@@ -91,43 +92,15 @@
    public bool SaveList(List<ErpItemType> departments)
    {
        var list = new List<MesItemType>();
        departments.ForEach(s =>
        if (departments == null || !departments.Any())
        {
            var entity = GetMesItemType(s);
            entity.Type = s.Type;
            list.Add(entity);
        });
            Console.WriteLine("警告: 传入的列表为空");
            return false;
        }
        var groupBy = list.GroupBy(s => s.Type)
            .ToDictionary(g => g.Key, g => g.ToList());
        var result = new List<bool>();
        foreach (var itemTypeGroup in groupBy)
            try
            {
                switch (itemTypeGroup.Key)
                {
                    case "0":
                        result.Add(InsertItemTypeBatch(itemTypeGroup.Value));
                        break;
                    case "1":
                        result.Add(DeleteItemTypeBatch(itemTypeGroup.Value));
                        break;
                    default:
                        throw new ArgumentNullException(
                            $"type没有{itemTypeGroup.Key}这个类型的参数");
                }
            }
            catch (Exception ex)
            {
                throw new ApplicationException($"批量操作失败: {ex.Message}", ex);
            }
        if (result.All(b => b))
            return true;
        throw new NotImplementedException("接口执行失败");
        // 逐条处理,全部成功才返回true(事务内批量处理更优,此处保持原有逻辑)
        var result = departments.Select(Save).ToList();
        return result.All(b => b);
    }
    private bool InsertItemTypeBatch(List<MesItemType> itemTypeList)