using Dapper; using Estsh.Core.Base; using Estsh.Core.Dapper; using Estsh.Core.Model.EnumUtil; using Estsh.Core.Models; using Estsh.Core.Repositories; using Estsh.Core.Wms.IRepositories; using System.Data; using System.Text; namespace Estsh.Core.Wms.Repositories { /// /// 拆分台车 /// public class SplitCarrierRepository : BaseRepository, ISplitCarrierRepository { public SplitCarrierRepository(DapperDbContext _dapperDbContext) : base(_dapperDbContext) { } /// /// 台车信息 /// /// /// public List GetCarrierByName(string rackNo) { using (IDbConnection dbConn = dapperDbContext.GetDbConnection()) { dbConn.Open(); StringBuilder stringBuilder = new StringBuilder(); stringBuilder.Append("select * from wms_rack_package (nolock) where rack_no= '" + rackNo + "' and enabled='Y'"); List sysLocates = dbConn.Query(stringBuilder.ToString()).ToList(); return sysLocates; } } public List GetCarrierByStockRackNo(string rackNo) { using (IDbConnection dbConn = dapperDbContext.GetDbConnection()) { dbConn.Open(); StringBuilder stringBuilder = new StringBuilder(); stringBuilder.Append("select * from sys_stock (nolock) where carton_no= '" + rackNo + "' and enabled='Y'"); List sysLocates = dbConn.Query(stringBuilder.ToString()).ToList(); return sysLocates; } } public List GetSysStockByNO(string cartonNo) { using (IDbConnection dbConn = dapperDbContext.GetDbConnection()) { dbConn.Open(); StringBuilder SqlStringBuilder = new StringBuilder(1024); SqlStringBuilder.Append("select * from sys_stock (nolock) where carton_no='"+ cartonNo + "' and carton_type=0 "); List sysLocates = dbConn.Query(SqlStringBuilder.ToString()).ToList(); return sysLocates; } } /// /// 产品条码号查询 /// /// /// public List GetSysStockBycartonNo(string rackNo, string cartonNo) { using (IDbConnection dbConn = dapperDbContext.GetDbConnection()) { dbConn.Open(); StringBuilder SqlStringBuilder = new StringBuilder(1024); SqlStringBuilder.Append("select a.*,b.rack_no from sys_stock a (nolock) "); SqlStringBuilder.Append("inner join(select a.rack_no,a.carton_no from wms_rack_package a (nolock) inner join sys_stock b (nolock) "); SqlStringBuilder.Append("on a.rack_no=b.carton_no and a.enabled='Y' and b.enabled='Y') b "); SqlStringBuilder.Append("on a.carton_no=b.carton_no where b.rack_no='"+ rackNo + "' and b.carton_no='"+ cartonNo + "' and a.enabled='Y' "); List sysLocates = dbConn.Query(SqlStringBuilder.ToString()).ToList(); return sysLocates; } } public List GetSysStockBySumQty(string rackNo) { using (IDbConnection dbConn = dapperDbContext.GetDbConnection()) { dbConn.Open(); StringBuilder SqlStringBuilder = new StringBuilder(1024); SqlStringBuilder.Append("select b.rack_no,a.part_no,sum(qty) qty from sys_stock a (nolock) "); SqlStringBuilder.Append("inner join(select a.rack_no,a.carton_no from wms_rack_package a (nolock) inner join sys_stock b (nolock) "); SqlStringBuilder.Append("on a.rack_no=b.carton_no and a.enabled='Y' and b.enabled='Y') b "); SqlStringBuilder.Append("on a.carton_no=b.carton_no where b.rack_no='" + rackNo + "' and a.enabled='Y' "); SqlStringBuilder.Append("group by b.rack_no,a.part_no"); List sysLocates = dbConn.Query(SqlStringBuilder.ToString()).ToList(); return sysLocates; } } public int UpdateStockByRackNo(string rackNo) { using (IDbConnection dbConn = dapperDbContext.GetDbConnection()) { dbConn.Open(); StringBuilder SqlStringBuilder = new StringBuilder(1024); SqlStringBuilder.Append("update sys_stock set enabled='N',update_userid=0,update_time='"+ DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")+"' where carton_no='" + rackNo + "' and enabled='Y' "); return dbConn.Execute(SqlStringBuilder.ToString()); } } public List GetSysStockByPartNoSumQty(string rackNo, string partNo) { using (IDbConnection dbConn = dapperDbContext.GetDbConnection()) { dbConn.Open(); StringBuilder SqlStringBuilder = new StringBuilder(1024); SqlStringBuilder.Append("select b.rack_no,a.part_no,sum(qty) qty from sys_stock a (nolock) "); SqlStringBuilder.Append("inner join(select a.rack_no,a.carton_no from wms_rack_package a (nolock) inner join sys_stock b (nolock) "); SqlStringBuilder.Append("on a.rack_no=b.carton_no and a.enabled='Y' and b.enabled='Y') b "); SqlStringBuilder.Append("on a.carton_no=b.carton_no where b.rack_no='" + rackNo + "' and a.part_no='" + partNo + "' and a.enabled='Y' "); SqlStringBuilder.Append("group by b.rack_no,a.part_no"); List sysLocates = dbConn.Query(SqlStringBuilder.ToString()).ToList(); return sysLocates; } } public List GetSysStockByPartInfo(string rackNo, string partNo) { using (IDbConnection dbConn = dapperDbContext.GetDbConnection()) { dbConn.Open(); StringBuilder SqlStringBuilder = new StringBuilder(1024); SqlStringBuilder.Append("select a.*,b.rack_no from sys_stock a (nolock) "); SqlStringBuilder.Append("inner join(select a.rack_no,a.carton_no from wms_rack_package a (nolock) inner join sys_stock b (nolock) "); SqlStringBuilder.Append("on a.rack_no=b.carton_no and a.enabled='Y' and b.enabled='Y') b "); SqlStringBuilder.Append("on a.carton_no=b.carton_no where b.rack_no='" + rackNo + "' and a.part_no='" + partNo + "' and a.enabled='Y' order by create_time "); List sysLocates = dbConn.Query(SqlStringBuilder.ToString()).ToList(); return sysLocates; } } /// /// 台车信息根据零件号 /// /// /// public List GetCarrierByPartNo(string cartonNo) { using (IDbConnection dbConn = dapperDbContext.GetDbConnection()) { dbConn.Open(); StringBuilder stringBuilder = new StringBuilder(); stringBuilder.Append("select * from wms_rack_package (nolock) where carton_no= '" + cartonNo + "'"); List sysLocates = dbConn.Query(stringBuilder.ToString()).ToList(); return sysLocates; } } public List GetCarrierByRackAndPartNo(string rackNo, string cartonNo) { using (IDbConnection dbConn = dapperDbContext.GetDbConnection()) { dbConn.Open(); StringBuilder stringBuilder = new StringBuilder(); stringBuilder.Append("select * from wms_rack_package (nolock) where rack_no='" + rackNo + "' and carton_no= '" + cartonNo + "'"); List sysLocates = dbConn.Query(stringBuilder.ToString()).ToList(); return sysLocates; } } public List CheckLocateStatus(string locateName) { using (IDbConnection dbConn = dapperDbContext.GetDbConnection()) { dbConn.Open(); string result = string.Empty; StringBuilder sql = new StringBuilder(1024); sql.Append(@"SELECT a.*,B.*,c.erp_warehouse FROM dbo.sys_locate a (nolock) LEFT JOIN sys_locate_part b (nolock) ON a.locate_id = b.locate_id LEFT join sys_zone as c (nolock) on a.zone_id=c.zone_id WHERE a.locate_name =@locateName "); DynamicParameters parameters = new DynamicParameters(); parameters.Add("@locateName", locateName); return dbConn.Query(sql.ToString(), parameters).ToList(); } } /// /// 获取订单编号 /// /// public string GetOrderNo(string stockOrder, string p) { using (IDbConnection dbConn = dapperDbContext.GetDbConnection()) { dbConn.Open(); DynamicParameters list = new DynamicParameters(); list.Add("@order_type", stockOrder); list.Add("@order_prefix", p); list.Add("@order_no", null, DbType.String, ParameterDirection.Output, 50); var hashtable = dbConn.Execute("sys_create_orderno", list, commandType: CommandType.StoredProcedure); string result = list.Get("@order_no"); return result; } } public int SQLTransaction(List sqlStrings, List parameterList) { using (IDbConnection dbConn = dapperDbContext.GetDbConnection()) { if (dbConn.State == ConnectionState.Closed) { dbConn.Open(); } //执行事务 IDbTransaction transaction = dbConn.BeginTransaction(); if (parameterList == null || parameterList.Count == 0) { try { for (int i = 0; i < sqlStrings.Count; i++) { dbConn.Execute(sqlStrings[i], null, transaction); } transaction.Commit(); return 1; } catch (Exception exception) { transaction.Rollback(); return 0; } } else { try { for (int i = 0; i < sqlStrings.Count; i++) { dbConn.Execute(sqlStrings[i], parameterList[i], transaction); } transaction.Commit(); return 1; } catch (Exception exception) { transaction.Rollback(); return 0; } } } } } }