using System; using System.Data; using System.Collections.Generic; using System.Text; using Microsoft.Practices.EnterpriseLibrary.Data; using DSWeb.Areas.CommMng.Models; using DSWeb.Areas.Storage.Models; namespace DSWeb.Storage.DAL { public class MsWMSDAL { #region 查询入库 static public List GetIndoDataList(string mblno, string condition = null, string sort = null, string order = null) { var strSql = new StringBuilder(); strSql.AppendLine("SELECT BSNO,MBLNO,WMSID,DODATE,GOODSNAME,PKGS,KGS,CHANGETYPE,CNTRNO"); strSql.AppendLine("FROM VW_OP_REP_WMSINDO S"); strSql.AppendLine($"WHERE MBLNO like '%{mblno}%' "); //if (!hasNoFee) //{ // strSql.AppendLine("AND (SELECT COUNT(1) FROM CH_FEE WHERE FEETYPE=1 AND FEESTATUS IN (0,8,9) AND CUSTOMERNAME=S.CUSTOMERNAME AND BSNO=S.BSNO)>0"); //} if (!string.IsNullOrWhiteSpace(condition)) { var obj = new { OPENID="", MBLNO = "", BSNO = "" }; var jsonObj = Newtonsoft.Json.JsonConvert.DeserializeAnonymousType(condition, obj); if (!string.IsNullOrWhiteSpace(jsonObj.MBLNO)) { strSql.Append($" and MBLNO='{jsonObj.MBLNO.Replace("'", "")}'"); } if (!string.IsNullOrWhiteSpace(jsonObj.BSNO)) { strSql.Append($" and BSNO='{jsonObj.BSNO.Replace("'", "")}'"); } if (!string.IsNullOrWhiteSpace(jsonObj.OPENID)) { var openid = jsonObj.BSNO.Replace("'", ""); strSql.Append($" and CUSTOMERNAME in(select infoclient from Disp_InfoClient where openid='{openid}')"); } else { strSql.Append($" and 1=2 "); } } if (!string.IsNullOrEmpty(sort)) { strSql.AppendLine($" order by {sort} {(string.IsNullOrWhiteSpace(order) ? string.Empty : order)}"); } else { strSql.AppendLine(" order by BSNO desc"); } return SetData(strSql); } private static List SetData(StringBuilder strSql) { var headList = new List(); Database db = DatabaseFactory.CreateDatabase(); using (IDataReader reader = db.ExecuteReader(CommandType.Text, strSql.ToString())) { while (reader.Read()) { IndoModel data = new IndoModel(); #region Set DB data to Object data.WMSID = Guid.Parse(reader["WMSID"].ToString()); data.MBLNO = Convert.ToString(reader["MBLNO"]); data.BSNO = Convert.ToString(reader["BSNO"]); data.DODATE =reader["DODATE"].ToString(); data.GOODSNAME = Convert.ToString(reader["GOODSNAME"]); data.PKGS = reader["PKGS"].ToString(); data.KGS = reader["KGS"].ToString(); data.CHANGETYPE = reader["CHANGETYPE"].ToString(); data.CNTRNO = reader["CNTRNO"].ToString(); #endregion headList.Add(data); } reader.Close(); } return headList; } #endregion #region 查询出库 static public List GetOutdoDataList(string mblno, string condition = null, string sort = null, string order = null) { var strSql = new StringBuilder(); strSql.AppendLine("SELECT WMSNO,MBLNO,WMSID,DODATE,GOODSNAME,PKGS,KGS,CHANGETYPE,CNTRNO"); strSql.AppendLine("FROM VW_OP_REP_WMSOUTDO S"); strSql.AppendLine($"WHERE MBLNO like '%{mblno}%' "); //if (!hasNoFee) //{ // strSql.AppendLine("AND (SELECT COUNT(1) FROM CH_FEE WHERE FEETYPE=1 AND FEESTATUS IN (0,8,9) AND CUSTOMERNAME=S.CUSTOMERNAME AND BSNO=S.BSNO)>0"); //} if (!string.IsNullOrWhiteSpace(condition)) { var obj = new { MBLNO = "", OPENID = "", BSNO = "" }; var jsonObj = Newtonsoft.Json.JsonConvert.DeserializeAnonymousType(condition, obj); if (!string.IsNullOrWhiteSpace(jsonObj.MBLNO)) { strSql.Append($" and MBLNO='{jsonObj.MBLNO.Replace("'", "")}'"); } if (!string.IsNullOrWhiteSpace(jsonObj.BSNO)) { strSql.Append($" and BSNO='{jsonObj.BSNO.Replace("'", "")}'"); } if (!string.IsNullOrWhiteSpace(jsonObj.OPENID)) { var openid = jsonObj.BSNO.Replace("'", ""); strSql.Append($" and CUSTOMERNAME in(select infoclient from Disp_InfoClient where openid='{openid}')"); } else { strSql.Append($" and 1=2 "); } } if (!string.IsNullOrEmpty(sort)) { strSql.AppendLine($" order by {sort} {(string.IsNullOrWhiteSpace(order) ? string.Empty : order)}"); } else { strSql.AppendLine(" order by WMSNO desc"); } return SetData2(strSql); } private static List SetData2(StringBuilder strSql) { var headList = new List(); Database db = DatabaseFactory.CreateDatabase(); using (IDataReader reader = db.ExecuteReader(CommandType.Text, strSql.ToString())) { while (reader.Read()) { OutdoModel data = new OutdoModel(); #region Set DB data to Object data.WMSID = Guid.Parse(reader["WMSID"].ToString()); data.MBLNO = Convert.ToString(reader["MBLNO"]); data.WMSNO = Convert.ToString(reader["WMSNO"]); data.DODATE = reader["DODATE"].ToString(); data.GOODSNAME = Convert.ToString(reader["GOODSNAME"]); data.PKGS = reader["PKGS"].ToString(); data.KGS = reader["KGS"].ToString(); data.CHANGETYPE = reader["CHANGETYPE"].ToString(); data.CNTRNO = reader["CNTRNO"].ToString(); #endregion headList.Add(data); } reader.Close(); } return headList; } #endregion #region 查询库存 static public List GetKuCunDataList(string openid, string condition = null, string sort = null, string order = null) { var strSql = new StringBuilder(); strSql.AppendLine("SELECT WMSID,CUSTOMERNAME,CUSTOMNO,GOODSNAME,PKGS_FIRST,PKGS,MBLNO,BSNO,CNTRNO,STOREHOUSENAME,AREANAME,AREACODE,STOREHOUSE"); strSql.AppendLine("FROM VW_OP_WMS_AREAGOODS S"); strSql.AppendLine($"WHERE CUSTOMERNAME in(select infoclient from Disp_InfoClient where openid='{openid}') "); if (!string.IsNullOrEmpty(sort)) { strSql.AppendLine($" order by {sort} {(string.IsNullOrWhiteSpace(order) ? string.Empty : order)}"); } else { strSql.AppendLine(" order by BSNO desc"); } return SetData3(strSql); } static public List GetDQKuCunDataList(string openid, string condition = null, string sort = null, string order = null) { var strSql = new StringBuilder(); strSql.AppendLine("SELECT MBLNO,count(PKGS_FIRST) as PKGS_FIRST,count(PKGS) as PKGS "); strSql.AppendLine("FROM VW_OP_WMS_AREAGOODS S"); strSql.AppendLine($"WHERE CUSTOMERNAME in(select infoclient from Disp_InfoClient where openid='{openid}') group by MBLNO "); return SetData4(strSql); } private static List SetData4(StringBuilder strSql) { var headList = new List(); Database db = DatabaseFactory.CreateDatabase(); using (IDataReader reader = db.ExecuteReader(CommandType.Text, strSql.ToString())) { while (reader.Read()) { KuCunModel data = new KuCunModel(); #region Set DB data to Object data.MBLNO = Convert.ToString(reader["MBLNO"]); data.PKGS = reader["PKGS"].ToString(); data.PKGS_FIRST = reader["PKGS_FIRST"].ToString(); #endregion headList.Add(data); } reader.Close(); } return headList; } private static List SetData3(StringBuilder strSql) { var headList = new List(); Database db = DatabaseFactory.CreateDatabase(); using (IDataReader reader = db.ExecuteReader(CommandType.Text, strSql.ToString())) { while (reader.Read()) { KuCunModel data = new KuCunModel(); #region Set DB data to Object data.WMSID = Guid.Parse(reader["WMSID"].ToString()); data.MBLNO = Convert.ToString(reader["MBLNO"]); data.BSNO = Convert.ToString(reader["BSNO"]); data.CUSTOMERNAME = reader["CUSTOMERNAME"].ToString(); data.GOODSNAME = Convert.ToString(reader["GOODSNAME"]); data.PKGS = reader["PKGS"].ToString(); data.PKGS_FIRST = reader["PKGS_FIRST"].ToString(); data.CUSTOMNO = reader["CUSTOMNO"].ToString(); data.CNTRNO = reader["CNTRNO"].ToString(); data.STOREHOUSENAME = reader["STOREHOUSENAME"].ToString(); data.AREANAME = reader["AREANAME"].ToString(); data.STOREHOUSE = reader["STOREHOUSE"].ToString(); data.AREACODE = reader["AREACODE"].ToString(); #endregion headList.Add(data); } reader.Close(); } return headList; } #endregion public static IndoModel GetOneIndoByWMSID(string wmsid) { var strSql = new StringBuilder(); strSql.AppendLine("SELECT * "); strSql.AppendLine("FROM VW_OP_REP_WMSINDO S"); strSql.AppendLine($"WHERE wmsid='{wmsid}'"); var list = SetData(strSql); if (list.Count > 0) { return list[0]; } return null; } public static OutdoModel GetOneOutdoByWMSID(string wmsid) { var strSql = new StringBuilder(); strSql.AppendLine("SELECT * "); strSql.AppendLine("FROM VW_OP_REP_WMSINDO S"); strSql.AppendLine($"WHERE wmsid='{wmsid}'"); var list = SetData2(strSql); if (list.Count > 0) { return list[0]; } return null; } #region 查询库存 static public List GetSTOREHOUSEList(string AREACODE="") { var strSql = new StringBuilder(); strSql.AppendLine($"SELECT * from OP_WMS_STOREHOUSE where AREACODE='{AREACODE}'"); return SetData_STOREHOUSE(strSql); } static public OP_WMS_STOREHOUSE GetSTOREHOUSE(string AREACODE = "") { var strSql = new StringBuilder(); strSql.AppendLine($"SELECT * from OP_WMS_STOREHOUSE where AREACODE='{AREACODE}'"); var _r = SetData_STOREHOUSE(strSql); if (_r.Count > 0) return _r[0]; return new OP_WMS_STOREHOUSE(); } private static List SetData_STOREHOUSE(StringBuilder strSql) { var headList = new List(); Database db = DatabaseFactory.CreateDatabase(); using (IDataReader reader = db.ExecuteReader(CommandType.Text, strSql.ToString())) { while (reader.Read()) { OP_WMS_STOREHOUSE data = new OP_WMS_STOREHOUSE(); #region Set DB data to Object data.Id = int.Parse(reader["Id"].ToString()); data.AREACODE = Convert.ToString(reader["AREACODE"]); data.AREANAME = Convert.ToString(reader["AREANAME"]); data.MAPHTML = Convert.ToString(reader["MAPHTML"]); #endregion headList.Add(data); } reader.Close(); } return headList; } #endregion } }