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 RecommendedInStockRepository : BaseRepository, IRecommendedInStockRepository { public RecommendedInStockRepository(DapperDbContext _dapperDbContext) : base(_dapperDbContext) { } //根据条码获取条码数据 public List GetStockByCarton(string cartonNo) { using (IDbConnection dbConn = dapperDbContext.GetDbConnection()) { dbConn.Open(); StringBuilder stringBuilder = new StringBuilder(); 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='" + cartonNo + "'"); List sysStocks = dbConn.Query(stringBuilder.ToString()).ToList(); return sysStocks; } } //根据供应商编号获取库区零件号 public List GetZonePartByVendorId(int VendorId) { using (IDbConnection dbConn = dapperDbContext.GetDbConnection()) { dbConn.Open(); StringBuilder stringBuilder = new StringBuilder(); stringBuilder.Append("SELECT * FROM dbo.sys_zone_part (nolock) WHERE vendor_id = '" + VendorId + "' and enabled='Y' ORDER BY priority "); List sysZoneParts = dbConn.Query(stringBuilder.ToString()).ToList(); return sysZoneParts; } } //根据分组号分组获取所有 public List GetStockByGroupNo(string groupNo) { using (IDbConnection dbConn = dapperDbContext.GetDbConnection()) { dbConn.Open(); StringBuilder stringBuilder = new StringBuilder(); stringBuilder.Append("SELECT * FROM dbo.sys_stock a (nolock) WHERE group_no = '" + groupNo + "' and status=40 and a.enabled='Y' "); List sysstockByGroupNoCount = dbConn.Query(stringBuilder.ToString()).ToList(); return sysstockByGroupNoCount; } } //根据分组号分组获取所有零件号 public List GetStockPartByGroupNo(string groupNo) { using (IDbConnection dbConn = dapperDbContext.GetDbConnection()) { dbConn.Open(); StringBuilder stringBuilder = new StringBuilder(); stringBuilder.Append("SELECT a.part_no FROM dbo.sys_stock a (nolock) WHERE group_no = '" + groupNo + "' and status=40 and a.enabled='Y' GROUP BY a.part_no "); List sysstockByGroupNoCount = dbConn.Query(stringBuilder.ToString()).ToList(); return sysstockByGroupNoCount; } } //根据零件号获取库区零件号信息,用于推荐库位 public List GetZonePartByPartNo(string partNo) { using (IDbConnection dbConn = dapperDbContext.GetDbConnection()) { dbConn.Open(); StringBuilder stringBuilder = new StringBuilder(); stringBuilder.Append("SELECT * FROM dbo.sys_zone_part (nolock) WHERE part_no = '" + partNo + "' and enabled='Y' ORDER BY priority "); List sysZoneParts = dbConn.Query(stringBuilder.ToString()).ToList(); return sysZoneParts; } } //根据库区查询库区下的库位 public List GetLocateByZoneName(string zoneName) { using (IDbConnection dbConn = dapperDbContext.GetDbConnection()) { dbConn.Open(); StringBuilder stringBuilder = new StringBuilder(); stringBuilder.Append("SELECT * FROM dbo.sys_locate a (nolock) LEFT JOIN sys_locate_part b (nolock) ON a.locate_id = b.locate_id WHERE zone_name = '" + zoneName + "' and a.enabled='Y'"); List sysLocates = dbConn.Query(stringBuilder.ToString()).ToList(); return sysLocates; } } public List GetLocateByZoneNameAndPartNo(string zoneName, string partNo) { using (IDbConnection dbConn = dapperDbContext.GetDbConnection()) { dbConn.Open(); StringBuilder stringBuilder = new StringBuilder(); stringBuilder.Append("SELECT * FROM dbo.sys_locate a (nolock) LEFT JOIN sys_locate_part b (nolock) ON a.locate_id = b.locate_id WHERE zone_name = '" + zoneName + "' and b.part_no='"+ partNo + "' and a.enabled='Y'"); List sysLocates = dbConn.Query(stringBuilder.ToString()).ToList(); return sysLocates; } } //根据库位获取所有在库的数量和 public SysStock GetStockByLocateName(string locateName) { using (IDbConnection dbConn = dapperDbContext.GetDbConnection()) { dbConn.Open(); StringBuilder stringBuilder = new StringBuilder(); stringBuilder.Append(" SELECT SUM(qty) as qty FROM dbo.sys_stock (nolock) WHERE locate_name = '" + locateName + "' AND status IN ('50','60','80') and enabled='Y' "); SysStock sysStocksQtySum = dbConn.QueryFirstOrDefault(stringBuilder.ToString());//库位在库数 return sysStocksQtySum; } } //根据库位获取零件号不为空的条码信息 public List GetStockByPartNoLocateName(string locateName) { using (IDbConnection dbConn = dapperDbContext.GetDbConnection()) { dbConn.Open(); StringBuilder stringBuilder = new StringBuilder(); stringBuilder.Append("SELECT * FROM dbo.sys_stock (nolock) WHERE part_no!='' and locate_name = '" + locateName + "' and enabled='Y'"); List sysStocks1 = dbConn.Query(stringBuilder.ToString()).ToList(); return sysStocks1; } } //根据库位名称获取库位信息 public List GetLocateInfoByLocateName(string locateName) { using (IDbConnection dbConn = dapperDbContext.GetDbConnection()) { dbConn.Open(); StringBuilder stringBuilder = new StringBuilder(); stringBuilder.Append("SELECT a.locate_id,a.locate_name,a.locate_type,a.locate_capacity,b.enum_desc as locate_typeDesc,a.enabled,a.zone_id,a.zone_name,a.warehouse_id,a.warehouse_name,c.part_no FROM dbo.sys_locate a (nolock) LEFT JOIN sys_enum b (nolock) ON b.enum_type='sys_locate_type' and a.locate_type=b.enum_value " + " LEFT JOIN dbo.sys_locate_part c (nolock) ON a.locate_id=c.locate_id WHERE a.locate_name = '" + locateName + "'"); List sysLocates = dbConn.Query(stringBuilder.ToString()).ToList(); return sysLocates; } } //根据分组号获取条码数量和 public List GetStockQtyByGroupNo(string groupNo) { using (IDbConnection dbConn = dapperDbContext.GetDbConnection()) { dbConn.Open(); StringBuilder stringBuilder = new StringBuilder(); stringBuilder.Append("SELECT SUM(qty) as qty FROM dbo.sys_stock (nolock) WHERE group_no = '" + groupNo + "' and status in (40) and enabled='Y' "); List sysStocks1 = dbConn.Query(stringBuilder.ToString()).ToList(); return sysStocks1; } } //根据分组号获取待入库的条码 public List GetStockInfoByGroupNo(string groupNo) { using (IDbConnection dbConn = dapperDbContext.GetDbConnection()) { dbConn.Open(); StringBuilder stringBuilder = new StringBuilder(); stringBuilder.Append("SELECT * FROM dbo.sys_stock (nolock) WHERE group_no = '" + groupNo + "' and status in (40) and enabled='Y' "); List sysStocks = dbConn.Query(stringBuilder.ToString()).ToList(); return sysStocks; } } //根据库位查询所有在库的条码 public List GetStockInfoByLocateName(string locateName) { using (IDbConnection dbConn = dapperDbContext.GetDbConnection()) { dbConn.Open(); StringBuilder stringBuilder = new StringBuilder(); stringBuilder.Append("SELECT * FROM sys_stock (nolock) WHERE locate_name='" + locateName + "' AND status in (50,60,80) AND enabled='Y'"); List sysStocks = dbConn.Query(stringBuilder.ToString()).ToList(); return sysStocks; } } ////根据分组号查询所有条码信息 //public List GetStockInfoByInGroupNo(string groupNo) //{ // using (IDbConnection dbConn = dapperDbContext.GetDbConnection()) // { // dbConn.Open(); // StringBuilder stringBuilder = new StringBuilder(); // stringBuilder.Append("SELECT * FROM dbo.sys_stock WHERE group_no = '" + groupNo + "' and status=50 and enabled='Y'"); // List sysstockByGroupNo = dbConn.Query(stringBuilder.ToString()).ToList(); // return sysstockByGroupNo; // } //} ////根据条码获取库存在库信息 //public List GetStockInfoByInCartonNo(string cartonNo) //{ // using (IDbConnection dbConn = dapperDbContext.GetDbConnection()) // { // dbConn.Open(); // StringBuilder stringBuilder = new StringBuilder(); // stringBuilder.Append("SELECT * FROM dbo.sys_stock WHERE carton_no = '" + cartonNo + "' and status=50 and enabled='Y'"); // List sysstockByCartonNo = dbConn.Query(stringBuilder.ToString()).ToList(); // return sysstockByCartonNo; // } //} public List GetStockInfoByInGroupNo(string groupNo) { using (IDbConnection dbConn = dapperDbContext.GetDbConnection()) { dbConn.Open(); StringBuilder stringBuilder = new StringBuilder(); stringBuilder.Append("SELECT a.part_no,a.part_spec,p.part_spec2,sum(qty) qty,locate_name,count(1) carton_qty FROM dbo.sys_stock a (nolock) left join sys_part p (nolock) on a.part_id=p.part_id WHERE group_no='" + groupNo + "' and status in (50) and a.enabled='Y' group by a.part_no,a.part_spec,p.part_spec2,locate_name"); List sysStocks = dbConn.Query(stringBuilder.ToString()).ToList(); return sysStocks; } } //根据条码获取库存在库信息 public List GetStockInfoByInCartonNo(string cartonNo) { using (IDbConnection dbConn = dapperDbContext.GetDbConnection()) { dbConn.Open(); StringBuilder stringBuilder = new StringBuilder(); stringBuilder.Append("SELECT a.part_no,a.part_spec,p.part_spec2,sum(qty) qty,locate_name,count(1) carton_qty FROM dbo.sys_stock a (nolock) left join sys_part p (nolock) on a.part_id=p.part_id WHERE carton_no = '" + cartonNo + "' and status in (50) and a.enabled='Y' group by a.part_no,a.part_spec,p.part_spec2,locate_name "); List sysStocks = dbConn.Query(stringBuilder.ToString()).ToList(); return sysStocks; } } //事务批量执行添加、修改 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; } } } } } }