using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using IWareDataAccess.EF; using IWareDataAccess.Entity.Base; using IWareDataAccess.Helper; namespace IWareDataAccess.Base.PALLET { public class PalletSqlFunc { /// /// 搜索表 /// /// /// /// public static List Search(PalletWebEntity webEntity, int page, int onePageNum, out string msg) { msg = ""; using (Model edm = new Model()) { var f = PredicateBuilder.True(); //便利所有属性 Type type = webEntity.GetType(); foreach (var i in type.GetProperties()) { object v = Helper.Helper.GetFieldValueByName(webEntity, i.Name); if (i.PropertyType == typeof(String)) { string value; if (v != null) { value = v.ToString(); f = f.And(x => Helper.Helper.GetFieldValueByName(x, i.Name) != null ? Helper.Helper.GetFieldValueByName(x, i.Name).ToString().Contains(value) : false); } } else { if (v != null) { f = f.And(x => Object.Equals(Helper.Helper.GetFieldValueByName(x, i.Name), v)); } } } List list = edm.BASE_PALLET.Where(f.Compile()).Skip((page - 1) * onePageNum).Take(onePageNum).ToList(); List pwlst=new List(); list.ForEach(x => { pwlst.Add(new PalletWebEntity() { id=x.ID, PalletType=x.PALLETTYPE, PalletCode=x.PALLETCODE, HeightMax=x.HEIGHTMAX, HeightMin=x.HEIGHTMIN, LengthMax=x.LENGTHMAX, LengthMin=x.LENGTHMIN, WidthMax=x.WIDTHMAX, WidthMin=x.WIDTHMIN }); }); return pwlst; } } /// /// 搜索视图数量 /// /// /// /// public static int SearchViewNum(PalletWebEntity webEntity) { using (Model edm = new Model()) { var f = PredicateBuilder.True(); //便利所有属性 Type type = webEntity.GetType(); foreach (var i in type.GetProperties()) { object v = Helper.Helper.GetFieldValueByName(webEntity, i.Name); if (i.PropertyType == typeof(String)) { string value; if (v != null) { value = v.ToString(); f = f.And(x => Helper.Helper.GetFieldValueByName(x, i.Name) != null ? Helper.Helper.GetFieldValueByName(x, i.Name).ToString().Contains(value) : false); } } else { if (v != null) { f = f.And(x => Object.Equals(Helper.Helper.GetFieldValueByName(x, i.Name), v)); } } } int num = edm.BASE_PALLET.Where(f.Compile()).Count(); return num; } } /// /// 添加修改托盘 /// /// /// public static bool AddOrUpdate(PalletWebEntity webEntity, out string msg) { msg = ""; using (Model edm = new Model()) { //查询是否已存在此托盘 BASE_PALLET pallet = edm.BASE_PALLET.FirstOrDefault(x => x.PALLETCODE==webEntity.PalletCode); if (pallet == null) { //无此库位,属于新建 pallet = new BASE_PALLET(); } else { msg = "该器具编号规格已存在!"; } pallet.PALLETCODE = webEntity.PalletCode ?? pallet.PALLETCODE; pallet.PALLETTYPE = webEntity.PalletType ?? pallet.PALLETTYPE; edm.BASE_PALLET.AddOrUpdateExtension(pallet); if (edm.SaveChanges() > 0) { return true; } else { return false; } } } /// /// 删除托盘 /// /// /// public static bool Delete(PalletWebEntity webDevice, out string msg) { msg = ""; using (Model edm = new Model()) { //查询是否已存在此权限 BASE_PALLET pallet = edm.BASE_PALLET.FirstOrDefault(x => x.PALLETCODE == webDevice.PalletCode); if (pallet == null) { //无此角色 msg = "无此规格"; return false; } else { edm.BASE_PALLET.Remove(pallet); return edm.SaveChanges()>0?true:false; } } } } }