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.
264 lines
12 KiB
C#
264 lines
12 KiB
C#
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
|
|
{
|
|
/// <summary>
|
|
/// 拆分台车
|
|
/// </summary>
|
|
public class SplitCarrierRepository : BaseRepository<BaseEntity>, ISplitCarrierRepository
|
|
{
|
|
public SplitCarrierRepository(DapperDbContext _dapperDbContext) : base(_dapperDbContext)
|
|
{
|
|
|
|
}
|
|
/// <summary>
|
|
/// 台车信息
|
|
/// </summary>
|
|
/// <param name="locateName"></param>
|
|
/// <returns></returns>
|
|
public List<WmsRackPackage> 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<WmsRackPackage> sysLocates = dbConn.Query<WmsRackPackage>(stringBuilder.ToString()).ToList();
|
|
return sysLocates;
|
|
}
|
|
}
|
|
|
|
public List<SysStock> 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<SysStock> sysLocates = dbConn.Query<SysStock>(stringBuilder.ToString()).ToList();
|
|
return sysLocates;
|
|
}
|
|
}
|
|
|
|
public List<SysStock> 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<SysStock> sysLocates = dbConn.Query<SysStock>(SqlStringBuilder.ToString()).ToList();
|
|
return sysLocates;
|
|
}
|
|
}
|
|
|
|
/// <summary>
|
|
/// 产品条码号查询
|
|
/// </summary>
|
|
/// <param name="locateName"></param>
|
|
/// <returns></returns>
|
|
public List<SysStock> 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<SysStock> sysLocates = dbConn.Query<SysStock>(SqlStringBuilder.ToString()).ToList();
|
|
return sysLocates;
|
|
}
|
|
}
|
|
|
|
public List<SysStock> 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<SysStock> sysLocates = dbConn.Query<SysStock>(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<SysStock> 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<SysStock> sysLocates = dbConn.Query<SysStock>(SqlStringBuilder.ToString()).ToList();
|
|
return sysLocates;
|
|
}
|
|
}
|
|
|
|
public List<SysStock> 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<SysStock> sysLocates = dbConn.Query<SysStock>(SqlStringBuilder.ToString()).ToList();
|
|
return sysLocates;
|
|
}
|
|
}
|
|
|
|
/// <summary>
|
|
/// 台车信息根据零件号
|
|
/// </summary>
|
|
/// <param name="rackNo"></param>
|
|
/// <returns></returns>
|
|
public List<WmsRackPackage> 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<WmsRackPackage> sysLocates = dbConn.Query<WmsRackPackage>(stringBuilder.ToString()).ToList();
|
|
return sysLocates;
|
|
}
|
|
}
|
|
|
|
|
|
public List<WmsRackPackage> 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<WmsRackPackage> sysLocates = dbConn.Query<WmsRackPackage>(stringBuilder.ToString()).ToList();
|
|
return sysLocates;
|
|
}
|
|
}
|
|
|
|
public List<SysLocate> 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<SysLocate>(sql.ToString(), parameters).ToList();
|
|
}
|
|
}
|
|
|
|
/// <summary>
|
|
/// 获取订单编号
|
|
/// </summary>
|
|
/// <returns></returns>
|
|
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<string>("@order_no");
|
|
return result;
|
|
}
|
|
}
|
|
|
|
public int SQLTransaction(List<string> sqlStrings, List<DynamicParameters> 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;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
}
|
|
}
|