using Dapper; using Estsh.Core.Base; using Estsh.Core.Dapper; using Estsh.Core.Wms.IRepositories; using Estsh.Core.Model.Result; using Estsh.Core.Repositories; using System.Collections; using System.Data; using System.Text; using System.Security.Cryptography; using System.Text.Json; using Estsh.Core.Models; using Newtonsoft.Json.Linq; using static Estsh.Core.Model.EnumUtil.WmsEnumUtil; namespace Estsh.Core.Wms.Repositories { public class MaterialRepository : BaseRepository, IMaterialRepository { public MaterialRepository(DapperDbContext _dapperDbContext) : base(_dapperDbContext) { } /// /// 获取箱条码信息 /// /// /// public List GetMaterialInfo(string cartonNo) { using (IDbConnection dbConn = dapperDbContext.GetDbConnection()) { dbConn.Open(); string result = string.Empty; StringBuilder stringBuilder = new StringBuilder(1024); stringBuilder.Append("SELECT a.*,b.enum_name as stock_status FROM sys_stock a (nolock) left join sys_enum b (nolock) on a.status=b.enum_value and b.enum_type = 'sys_stock_status' WHERE carton_no=@carton_no"); DynamicParameters parameters = new DynamicParameters(); parameters.Add("@carton_no", cartonNo); return dbConn.Query(stringBuilder.ToString(), parameters).ToList(); } } public int ScanCode(string cartonNo) { using (IDbConnection dbConn = dapperDbContext.GetDbConnection()) { dbConn.Open(); string result = string.Empty; StringBuilder sql = new StringBuilder(1024); sql.Append("insert into wms_scan_code values(@carton_no,@create_time) "); DynamicParameters parameters = new DynamicParameters(); parameters.Add("@carton_no", cartonNo); parameters.Add("@create_time", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")); return dbConn.Execute(sql.ToString(), parameters); } } public List SpellCode(string cartonNo) { using (IDbConnection dbConn = dapperDbContext.GetDbConnection()) { dbConn.Open(); string result = string.Empty; StringBuilder sql = new StringBuilder(1024); sql.Append(" select * from sys_stock (nolock) where qty < snp_qty and status='50' and enabled='Y' and part_no in ( select part_no from sys_stock (nolock) where carton_no=@carton_no )"); DynamicParameters parameters = new DynamicParameters(); parameters.Add("@carton_no", cartonNo); return dbConn.Query(sql.ToString(), parameters).ToList(); } } public List TailBox(string cartonNo) { using (IDbConnection dbConn = dapperDbContext.GetDbConnection()) { dbConn.Open(); string result = string.Empty; StringBuilder sql = new StringBuilder(1024); sql.Append(" select * from sys_stock (nolock) where qty != snp_qty and status='50' and carton_type='0' and enabled='Y' and part_no=@carton_no "); DynamicParameters parameters = new DynamicParameters(); parameters.Add("@carton_no", cartonNo); return dbConn.Query(sql.ToString(), parameters).ToList(); } } /// /// 拆分 箱条码 /// /// /// /// /// /// public List CheckMaterialSplit(List oldStock, int splitNum, string loginId, int splitCount) { using (IDbConnection dbConn = dapperDbContext.GetDbConnection()) { dbConn.Open(); List sqlStrings = new List(); List parameterList = new List(); decimal oldQty = oldStock[0].Qty; decimal newQty = oldStock[0].Qty - splitNum; //更新条码表,数量 StringBuilder updateString = new StringBuilder(1024); updateString.Append("update sys_stock set qty=@qty, update_userid=@update_userid,update_time=@update_time where carton_no=@carton_no "); DynamicParameters updateStringparameters = new DynamicParameters(); updateStringparameters.Add("@qty", newQty); updateStringparameters.Add("@carton_no", oldStock[0].CartonNo); updateStringparameters.Add("@update_userid", loginId); updateStringparameters.Add("@update_time", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")); sqlStrings.Add(updateString.ToString()); parameterList.Add(updateStringparameters); //新增 sys_stock_trans 事务表 #region sys_stock_trans 事务表 StringBuilder updateString4 = new StringBuilder(1024); updateString4.Append(@" INSERT INTO[dbo].[sys_stock_trans] ([trans_code] ,[carton_no] ,[part_id] ,[part_no] ,[part_spec] ,[src_locate_id] ,[src_locate_name] ,[dest_locate_id] ,[dest_locate_name] ,[old_qty] ,[new_qty] ,[trans_qty] ,[old_status] ,[new_status] ,[old_qms_status] ,[new_qms_status] ,[unit] ,[factory_id] ,[factory_code] ,[src_erp_warehouse] ,[dest_erp_warehouse] ,[src_warehouse_id] ,[src_warehouse_name] ,[dest_warehouse_id] ,[dest_warehouse_name] ,[src_zone_id] ,[src_zone_name] ,[dest_zone_id] ,[dest_zone_name] ,[enabled] ,[update_userid] ,[update_time] ,[create_userid] ,[create_time] ,[guid]) VALUES (@trans_code,@carton_no,@part_id,@part_no,@part_spec,@src_locate_id ,@src_locate_name ,@dest_locate_id ,@dest_locate_name ,@old_qty ,@new_qty ,@trans_qty ,@old_status ,@new_status ,@old_qms_status ,@new_qms_status ,@unit ,@factory_id ,@factory_code ,@src_erp_warehouse ,@dest_erp_warehouse ,@src_warehouse_id ,@src_warehouse_name ,@dest_warehouse_id ,@dest_warehouse_name ,@src_zone_id ,@src_zone_name ,@dest_zone_id ,@dest_zone_name ,@enabled ,@update_userid ,@update_time ,@create_userid ,@create_time ,@guid )"); DynamicParameters updateStringparameters4 = new DynamicParameters(); updateStringparameters4.Add("@trans_code", (int)TransType.PART_SPLIT); updateStringparameters4.Add("@carton_no", oldStock[0].CartonNo); updateStringparameters4.Add("@part_id", oldStock[0].PartId); updateStringparameters4.Add("@part_no", oldStock[0].PartNo); updateStringparameters4.Add("@part_spec", oldStock[0].PartSpec); updateStringparameters4.Add("@src_locate_id", oldStock[0].LocateId); updateStringparameters4.Add("@src_locate_name", oldStock[0].LocateName); updateStringparameters4.Add("@dest_locate_id", oldStock[0].LocateId); updateStringparameters4.Add("@dest_locate_name", oldStock[0].LocateName); updateStringparameters4.Add("@old_qty", oldQty); updateStringparameters4.Add("@new_qty", newQty); updateStringparameters4.Add("@trans_qty", oldStock[0].Qty); updateStringparameters4.Add("@old_status", oldStock[0].Status); updateStringparameters4.Add("@new_status", oldStock[0].Status); updateStringparameters4.Add("@old_qms_status", oldStock[0].QmsStatus); updateStringparameters4.Add("@new_qms_status", oldStock[0].QmsStatus); updateStringparameters4.Add("@unit", oldStock[0].Unit); updateStringparameters4.Add("@factory_id", oldStock[0].FactoryId); updateStringparameters4.Add("@factory_code", oldStock[0].FactoryCode); updateStringparameters4.Add("@src_erp_warehouse", oldStock[0].ErpWarehouse); updateStringparameters4.Add("@dest_erp_warehouse", oldStock[0].ErpWarehouse); updateStringparameters4.Add("@src_warehouse_id", oldStock[0].WarehouseId); updateStringparameters4.Add("@src_warehouse_name", oldStock[0].WarehouseName); updateStringparameters4.Add("@dest_warehouse_id", oldStock[0].WarehouseId); updateStringparameters4.Add("@dest_warehouse_name", oldStock[0].WarehouseName); updateStringparameters4.Add("@src_zone_id", oldStock[0].ZoneId); updateStringparameters4.Add("@src_zone_name", oldStock[0].ZoneName); updateStringparameters4.Add("@dest_zone_id", oldStock[0].ZoneId); updateStringparameters4.Add("@dest_zone_name", oldStock[0].ZoneName); updateStringparameters4.Add("@enabled", oldStock[0].Enabled); updateStringparameters4.Add("@update_userid", loginId); updateStringparameters4.Add("@update_time", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")); updateStringparameters4.Add("@create_userid", loginId); updateStringparameters4.Add("@create_time", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")); updateStringparameters4.Add("@guid", Guid.NewGuid()); sqlStrings.Add(updateString4.ToString()); parameterList.Add(updateStringparameters4); #endregion oldStock[0].CartonNo = checkCartonNo(oldStock[0].CartonNo, splitCount); oldStock[0].Qty = splitNum; //插入拆分出的箱条码 #region 插入拆分出的箱条码 StringBuilder updateString3 = new StringBuilder(1024); updateString3.Append(@" INSERT INTO [dbo].[sys_stock] ([vendor_id] ,[vendor_code] ,[carton_no] ,[part_id] ,[part_no] ,[part_spec] ,[lot_no] ,[fix_lot_no] ,[status] ,[qty] ,[snp_qty] ,[locate_id] ,[locate_name] ,[group_no] ,[erp_warehouse] ,[date_code] ,[qms_status] ,[ref_order_no] ,[unit] ,[dock] ,[warehouse_id] ,[warehouse_name] ,[zone_id] ,[zone_name] ,[printed] ,[print_time] ,[remark] ,[factory_id] ,[factory_code] ,[enabled] ,[create_userid] ,[create_time] ,[update_userid] ,[update_time] ,[guid]) VALUES(@vendor_id,@vendor_code,@carton_no,@part_id,@part_no,@part_spec,@lot_no,@fix_lot_no,@status,@qty,@snp_qty ,@locate_id,@locate_name,@group_no,@erp_warehouse,@date_code,@qms_status,@ref_order_no,@unit,@dock,@warehouse_id,@warehouse_name,@zone_id,@zone_name ,@printed,@print_time,@remark,@factory_id,@factory_code,@enabled,@create_userid,@create_time,@update_userid,@update_time,@guid )"); DynamicParameters updateStringparameters3 = new DynamicParameters(); updateStringparameters3.Add("@vendor_id", oldStock[0].VendorId); updateStringparameters3.Add("@vendor_code", oldStock[0].VendorCode); updateStringparameters3.Add("@carton_no", oldStock[0].CartonNo); updateStringparameters3.Add("@part_id", oldStock[0].PartId); updateStringparameters3.Add("@part_no", oldStock[0].PartNo); updateStringparameters3.Add("@part_spec", oldStock[0].PartSpec); updateStringparameters3.Add("@lot_no", oldStock[0].LotNo); updateStringparameters3.Add("@fix_lot_no", oldStock[0].FixLotNo); updateStringparameters3.Add("@status", oldStock[0].Status); updateStringparameters3.Add("@qty", splitNum); updateStringparameters3.Add("@snp_qty", oldStock[0].SnpQty); updateStringparameters3.Add("@locate_id", oldStock[0].LocateId); updateStringparameters3.Add("@locate_name", oldStock[0].LocateName); updateStringparameters3.Add("@group_no", oldStock[0].GroupNo); updateStringparameters3.Add("@erp_warehouse", oldStock[0].ErpWarehouse); updateStringparameters3.Add("@date_code", oldStock[0].DateCode); updateStringparameters3.Add("@qms_status", oldStock[0].QmsStatus); updateStringparameters3.Add("@ref_order_no", oldStock[0].RefOrderNo); updateStringparameters3.Add("@unit", oldStock[0].Unit); updateStringparameters3.Add("@dock", oldStock[0].Dock); updateStringparameters3.Add("@warehouse_id", oldStock[0].WarehouseId); updateStringparameters3.Add("@warehouse_name", oldStock[0].WarehouseName); updateStringparameters3.Add("@zone_id", oldStock[0].ZoneId); updateStringparameters3.Add("@zone_name", oldStock[0].ZoneName); updateStringparameters3.Add("@printed", oldStock[0].Printed); updateStringparameters3.Add("@print_time", oldStock[0].PrintTime); updateStringparameters3.Add("@remark", oldStock[0].Remark); updateStringparameters3.Add("@factory_id", oldStock[0].FactoryId); updateStringparameters3.Add("@factory_code", oldStock[0].FactoryCode); updateStringparameters3.Add("@enabled", oldStock[0].Enabled); updateStringparameters3.Add("@update_userid", loginId); updateStringparameters3.Add("@update_time", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")); updateStringparameters3.Add("@create_userid", loginId); updateStringparameters3.Add("@create_time", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")); updateStringparameters3.Add("@guid", Guid.NewGuid()); sqlStrings.Add(updateString3.ToString()); parameterList.Add(updateStringparameters3); #endregion //新增 sys_stock_trans 事务表 #region sys_stock_trans 事务表 StringBuilder updateString5 = new StringBuilder(1024); updateString5.Append(@" INSERT INTO[dbo].[sys_stock_trans] ([trans_code] ,[carton_no] ,[part_id] ,[part_no] ,[part_spec] ,[src_locate_id] ,[src_locate_name] ,[dest_locate_id] ,[dest_locate_name] ,[old_qty] ,[new_qty] ,[trans_qty] ,[old_status] ,[new_status] ,[old_qms_status] ,[new_qms_status] ,[unit] ,[factory_id] ,[factory_code] ,[src_erp_warehouse] ,[dest_erp_warehouse] ,[src_warehouse_id] ,[src_warehouse_name] ,[dest_warehouse_id] ,[dest_warehouse_name] ,[src_zone_id] ,[src_zone_name] ,[dest_zone_id] ,[dest_zone_name] ,[enabled] ,[update_userid] ,[update_time] ,[create_userid] ,[create_time] ,[guid]) VALUES (@trans_code,@carton_no,@part_id,@part_no,@part_spec,@src_locate_id ,@src_locate_name ,@dest_locate_id ,@dest_locate_name ,@old_qty ,@new_qty ,@trans_qty ,@old_status ,@new_status ,@old_qms_status ,@new_qms_status ,@unit ,@factory_id ,@factory_code ,@src_erp_warehouse ,@dest_erp_warehouse ,@src_warehouse_id ,@src_warehouse_name ,@dest_warehouse_id ,@dest_warehouse_name ,@src_zone_id ,@src_zone_name ,@dest_zone_id ,@dest_zone_name ,@enabled ,@update_userid ,@update_time ,@create_userid ,@create_time ,@guid )"); DynamicParameters updateStringparameters5 = new DynamicParameters(); updateStringparameters5.Add("@trans_code", (int)TransType.PART_SPLIT); updateStringparameters5.Add("@carton_no", oldStock[0].CartonNo); updateStringparameters5.Add("@part_id", oldStock[0].PartId); updateStringparameters5.Add("@part_no", oldStock[0].PartNo); updateStringparameters5.Add("@part_spec", oldStock[0].PartSpec); updateStringparameters5.Add("@src_locate_id", oldStock[0].LocateId); updateStringparameters5.Add("@src_locate_name", oldStock[0].LocateName); updateStringparameters5.Add("@dest_locate_id", oldStock[0].LocateId); updateStringparameters5.Add("@dest_locate_name", oldStock[0].LocateName); updateStringparameters5.Add("@old_qty", 0); updateStringparameters5.Add("@new_qty", splitNum); updateStringparameters5.Add("@trans_qty", oldStock[0].Qty); updateStringparameters5.Add("@old_status", oldStock[0].Status); updateStringparameters5.Add("@new_status", oldStock[0].Status); updateStringparameters5.Add("@old_qms_status", oldStock[0].QmsStatus); updateStringparameters5.Add("@new_qms_status", oldStock[0].QmsStatus); updateStringparameters5.Add("@unit", oldStock[0].Unit); updateStringparameters5.Add("@factory_id", oldStock[0].FactoryId); updateStringparameters5.Add("@factory_code", oldStock[0].FactoryCode); updateStringparameters5.Add("@src_erp_warehouse", oldStock[0].ErpWarehouse); updateStringparameters5.Add("@dest_erp_warehouse", oldStock[0].ErpWarehouse); updateStringparameters5.Add("@src_warehouse_id", oldStock[0].WarehouseId); updateStringparameters5.Add("@src_warehouse_name", oldStock[0].WarehouseName); updateStringparameters5.Add("@dest_warehouse_id", oldStock[0].WarehouseId); updateStringparameters5.Add("@dest_warehouse_name", oldStock[0].WarehouseName); updateStringparameters5.Add("@src_zone_id", oldStock[0].ZoneId); updateStringparameters5.Add("@src_zone_name", oldStock[0].ZoneName); updateStringparameters5.Add("@dest_zone_id", oldStock[0].ZoneId); updateStringparameters5.Add("@dest_zone_name", oldStock[0].ZoneName); updateStringparameters5.Add("@enabled", oldStock[0].Enabled); updateStringparameters5.Add("@update_userid", loginId); updateStringparameters5.Add("@update_time", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")); updateStringparameters5.Add("@create_userid", loginId); updateStringparameters5.Add("@create_time", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")); updateStringparameters5.Add("@guid", Guid.NewGuid()); sqlStrings.Add(updateString5.ToString()); parameterList.Add(updateStringparameters5); #endregion //执行事务 IDbTransaction transaction = dbConn.BeginTransaction(); bool successCount = true; for (int i = 0; i < sqlStrings.Count; i++) { if (dbConn.Execute(sqlStrings[i], parameterList[i], transaction) < 1) { successCount = false; } } if (successCount) { transaction.Commit(); return oldStock; } else { transaction.Rollback(); return null; } } } /// /// 拆分 验证箱条码是否存在 /// /// /// /// public string checkCartonNo(string carton, int splitCount) { List MaterialInfo = GetMaterialInfo(carton + "-" + splitCount); if (MaterialInfo.Count > 0) { //有重复 return checkCartonNo(carton, splitCount + 1); } else { return carton + "-" + splitCount; } } public List CheckMaterialConsolidation(List hostList, List SecondaryList, string loginId) { using (IDbConnection dbConn = dapperDbContext.GetDbConnection()) { dbConn.Open(); List sqlStrings = new List(); List parameterList = new List(); //更新主箱条码数量 StringBuilder updateString = new StringBuilder(1024); updateString.Append("update sys_stock set qty=@qty , update_userid=@update_userid,update_time=@update_time where carton_no=@carton_no "); DynamicParameters updateStringparameters = new DynamicParameters(); updateStringparameters.Add("@qty", hostList[0].Qty + SecondaryList[0].Qty); updateStringparameters.Add("@carton_no", hostList[0].CartonNo); updateStringparameters.Add("@update_userid", loginId); updateStringparameters.Add("@update_time", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")); sqlStrings.Add(updateString.ToString()); parameterList.Add(updateStringparameters); //新增 sys_stock_trans 事务表 #region sys_stock_trans 事务表 StringBuilder updateString4 = new StringBuilder(1024); updateString4.Append(@" INSERT INTO[dbo].[sys_stock_trans] ([trans_code] ,[carton_no] ,[part_id] ,[part_no] ,[part_spec] ,[src_locate_id] ,[src_locate_name] ,[dest_locate_id] ,[dest_locate_name] ,[old_qty] ,[new_qty] ,[trans_qty] ,[old_status] ,[new_status] ,[old_qms_status] ,[new_qms_status] ,[unit] ,[factory_id] ,[factory_code] ,[src_erp_warehouse] ,[dest_erp_warehouse] ,[src_warehouse_id] ,[src_warehouse_name] ,[dest_warehouse_id] ,[dest_warehouse_name] ,[src_zone_id] ,[src_zone_name] ,[dest_zone_id] ,[dest_zone_name] ,[enabled] ,[update_userid] ,[update_time] ,[create_userid] ,[create_time] ,[guid]) VALUES (@trans_code,@carton_no,@part_id,@part_no,@part_spec,@src_locate_id ,@src_locate_name ,@dest_locate_id ,@dest_locate_name ,@old_qty ,@new_qty ,@trans_qty ,@old_status ,@new_status ,@old_qms_status ,@new_qms_status ,@unit ,@factory_id ,@factory_code ,@src_erp_warehouse ,@dest_erp_warehouse ,@src_warehouse_id ,@src_warehouse_name ,@dest_warehouse_id ,@dest_warehouse_name ,@src_zone_id ,@src_zone_name ,@dest_zone_id ,@dest_zone_name ,@enabled ,@update_userid ,@update_time ,@create_userid ,@create_time ,@guid )"); DynamicParameters updateStringparameters4 = new DynamicParameters(); updateStringparameters4.Add("@trans_code", (int)TransType.PART_MERGE); updateStringparameters4.Add("@carton_no", hostList[0].CartonNo); updateStringparameters4.Add("@part_id", hostList[0].PartId); updateStringparameters4.Add("@part_no", hostList[0].PartNo); updateStringparameters4.Add("@part_spec", hostList[0].PartSpec); updateStringparameters4.Add("@src_locate_id", hostList[0].LocateId); updateStringparameters4.Add("@src_locate_name", hostList[0].LocateName); updateStringparameters4.Add("@dest_locate_id", hostList[0].LocateId); updateStringparameters4.Add("@dest_locate_name", hostList[0].LocateName); updateStringparameters4.Add("@old_qty", hostList[0].Qty); updateStringparameters4.Add("@new_qty", hostList[0].Qty + SecondaryList[0].Qty); updateStringparameters4.Add("@trans_qty", hostList[0].Qty); updateStringparameters4.Add("@old_status", hostList[0].Status); updateStringparameters4.Add("@new_status", hostList[0].Status); updateStringparameters4.Add("@old_qms_status", hostList[0].QmsStatus); updateStringparameters4.Add("@new_qms_status", hostList[0].QmsStatus); updateStringparameters4.Add("@unit", hostList[0].Unit); updateStringparameters4.Add("@factory_id", hostList[0].FactoryId); updateStringparameters4.Add("@factory_code", hostList[0].FactoryCode); updateStringparameters4.Add("@src_erp_warehouse", hostList[0].ErpWarehouse); updateStringparameters4.Add("@dest_erp_warehouse", hostList[0].ErpWarehouse); updateStringparameters4.Add("@src_warehouse_id", hostList[0].WarehouseId); updateStringparameters4.Add("@src_warehouse_name", hostList[0].WarehouseName); updateStringparameters4.Add("@dest_warehouse_id", hostList[0].WarehouseId); updateStringparameters4.Add("@dest_warehouse_name", hostList[0].WarehouseName); updateStringparameters4.Add("@src_zone_id", hostList[0].ZoneId); updateStringparameters4.Add("@src_zone_name", hostList[0].ZoneName); updateStringparameters4.Add("@dest_zone_id", hostList[0].ZoneId); updateStringparameters4.Add("@dest_zone_name", hostList[0].ZoneName); updateStringparameters4.Add("@enabled", hostList[0].Enabled); updateStringparameters4.Add("@update_userid", loginId); updateStringparameters4.Add("@update_time", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")); updateStringparameters4.Add("@create_userid", loginId); updateStringparameters4.Add("@create_time", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")); updateStringparameters4.Add("@guid", Guid.NewGuid()); sqlStrings.Add(updateString4.ToString()); parameterList.Add(updateStringparameters4); #endregion //更新副箱条码数量 StringBuilder updateString2 = new StringBuilder(1024); updateString2.Append("update sys_stock set qty=@qty,Enabled=@Enabled, update_userid=@update_userid,update_time=@update_time where carton_no=@carton_no "); DynamicParameters updateStringparameters2 = new DynamicParameters(); updateStringparameters2.Add("@qty", 0); updateStringparameters2.Add("@carton_no", SecondaryList[0].CartonNo); updateStringparameters2.Add("@Enabled", "N"); updateStringparameters2.Add("@update_userid", loginId); updateStringparameters2.Add("@update_time", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")); sqlStrings.Add(updateString2.ToString()); parameterList.Add(updateStringparameters2); //新增 sys_stock_trans 事务表 #region sys_stock_trans 事务表 //StringBuilder updateString5 = new StringBuilder(1024); //updateString5.Append(@" INSERT INTO[dbo].[sys_stock_trans] // ([trans_code] // ,[carton_no] // ,[part_id] // ,[part_no] // ,[part_spec] // ,[src_locate_id] // ,[src_locate_name] // ,[dest_locate_id] // ,[dest_locate_name] // ,[old_qty] // ,[new_qty] // ,[trans_qty] // ,[old_status] // ,[new_status] // ,[old_qms_status] // ,[new_qms_status] // ,[unit] // ,[factory_id] // ,[factory_code] // ,[src_erp_warehouse] // ,[dest_erp_warehouse] // ,[src_warehouse_id] // ,[src_warehouse_name] // ,[dest_warehouse_id] // ,[dest_warehouse_name] // ,[src_zone_id] // ,[src_zone_name] // ,[dest_zone_id] // ,[dest_zone_name] // ,[enabled] // ,[update_userid] // ,[update_time] // ,[create_userid] // ,[create_time] // ,[guid]) // VALUES (@trans_code,@carton_no,@part_id,@part_no,@part_spec,@src_locate_id ,@src_locate_name ,@dest_locate_id ,@dest_locate_name ,@old_qty // ,@new_qty ,@trans_qty ,@old_status ,@new_status ,@old_qms_status ,@new_qms_status ,@unit ,@factory_id ,@factory_code ,@src_erp_warehouse ,@dest_erp_warehouse ,@src_warehouse_id ,@src_warehouse_name ,@dest_warehouse_id ,@dest_warehouse_name ,@src_zone_id ,@src_zone_name ,@dest_zone_id ,@dest_zone_name ,@enabled ,@update_userid ,@update_time ,@create_userid ,@create_time ,@guid )"); //DynamicParameters updateStringparameters5 = new DynamicParameters(); //updateStringparameters5.Add("@trans_code", (int)TransType.PART_MERGE); //updateStringparameters5.Add("@carton_no", SecondaryList[0].CartonNo); //updateStringparameters5.Add("@part_id", SecondaryList[0].PartId); //updateStringparameters5.Add("@part_no", SecondaryList[0].PartNo); //updateStringparameters5.Add("@part_spec", SecondaryList[0].PartSpec); //updateStringparameters5.Add("@src_locate_id", SecondaryList[0].LocateId); //updateStringparameters5.Add("@src_locate_name", SecondaryList[0].LocateName); //updateStringparameters5.Add("@dest_locate_id", SecondaryList[0].LocateId); //updateStringparameters5.Add("@dest_locate_name", SecondaryList[0].LocateName); //updateStringparameters5.Add("@old_qty", SecondaryList[0].Qty); //updateStringparameters5.Add("@new_qty", 0); //updateStringparameters5.Add("@trans_qty", SecondaryList[0].Qty); //updateStringparameters5.Add("@old_status", SecondaryList[0].Status); //updateStringparameters5.Add("@new_status", "N"); //updateStringparameters5.Add("@old_qms_status", SecondaryList[0].QmsStatus); //updateStringparameters5.Add("@new_qms_status", SecondaryList[0].QmsStatus); //updateStringparameters5.Add("@unit", SecondaryList[0].Unit); //updateStringparameters5.Add("@factory_id", SecondaryList[0].FactoryId); //updateStringparameters5.Add("@factory_code", SecondaryList[0].FactoryCode); //updateStringparameters5.Add("@src_erp_warehouse", SecondaryList[0].ErpWarehouse); //updateStringparameters5.Add("@dest_erp_warehouse", SecondaryList[0].ErpWarehouse); //updateStringparameters5.Add("@src_warehouse_id", SecondaryList[0].WarehouseId); //updateStringparameters5.Add("@src_warehouse_name", SecondaryList[0].WarehouseName); //updateStringparameters5.Add("@dest_warehouse_id", SecondaryList[0].WarehouseId); //updateStringparameters5.Add("@dest_warehouse_name", SecondaryList[0].WarehouseName); //updateStringparameters5.Add("@src_zone_id", SecondaryList[0].ZoneId); //updateStringparameters5.Add("@src_zone_name", SecondaryList[0].ZoneName); //updateStringparameters5.Add("@dest_zone_id", SecondaryList[0].ZoneId); //updateStringparameters5.Add("@dest_zone_name", SecondaryList[0].ZoneName); //updateStringparameters5.Add("@enabled", SecondaryList[0].Enabled); //updateStringparameters5.Add("@update_userid", loginId); //updateStringparameters5.Add("@update_time", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")); //updateStringparameters5.Add("@create_userid", loginId); //updateStringparameters5.Add("@create_time", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")); //updateStringparameters5.Add("@guid", Guid.NewGuid()); //sqlStrings.Add(updateString5.ToString()); //parameterList.Add(updateStringparameters5); #endregion //执行事务 IDbTransaction transaction = dbConn.BeginTransaction(); bool successCount = true; for (int i = 0; i < sqlStrings.Count; i++) { if (dbConn.Execute(sqlStrings[i], parameterList[i], transaction) < 1) { successCount = false; } } if (successCount) { transaction.Commit(); return SecondaryList; } else { transaction.Rollback(); return null; } } } } }