You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

659 lines
40 KiB
C#

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<BaseEntity>, IMaterialRepository
{
public MaterialRepository(DapperDbContext _dapperDbContext) : base(_dapperDbContext)
{
}
/// <summary>
/// 获取箱条码信息
/// </summary>
/// <param name="cartonNo"></param>
/// <returns></returns>
public List<SysStock> 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<SysStock>(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<SysStock> 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<SysStock>(sql.ToString(), parameters).ToList();
}
}
public List<SysStock> 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<SysStock>(sql.ToString(), parameters).ToList();
}
}
/// <summary>
/// 拆分 箱条码
/// </summary>
/// <param name="oldStock"></param>
/// <param name="splitNum"></param>
/// <param name="loginId"></param>
/// <param name="splitCount"></param>
/// <returns></returns>
public List<SysStock> CheckMaterialSplit(List<SysStock> oldStock, int splitNum, string loginId, int splitCount)
{
using (IDbConnection dbConn = dapperDbContext.GetDbConnection())
{
dbConn.Open();
List<string> sqlStrings = new List<string>();
List<DynamicParameters> parameterList = new List<DynamicParameters>();
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;
}
}
}
/// <summary>
/// 拆分 验证箱条码是否存在
/// </summary>
/// <param name="carton"></param>
/// <param name="splitCount"></param>
/// <returns></returns>
public string checkCartonNo(string carton, int splitCount)
{
List<SysStock> MaterialInfo = GetMaterialInfo(carton + "-" + splitCount);
if (MaterialInfo.Count > 0)
{
//有重复
return checkCartonNo(carton, splitCount + 1);
}
else
{
return carton + "-" + splitCount;
}
}
public List<SysStock> CheckMaterialConsolidation(List<SysStock> hostList, List<SysStock> SecondaryList, string loginId)
{
using (IDbConnection dbConn = dapperDbContext.GetDbConnection())
{
dbConn.Open();
List<string> sqlStrings = new List<string>();
List<DynamicParameters> parameterList = new List<DynamicParameters>();
//更新主箱条码数量
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;
}
}
}
}
}