using IWareDataAccess.EF; using IWareDataAccess.Entity.Base; using IWareDataAccess.Helper; using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace IWareDataAccess.Base.ITEMSTORAGE { public class ItemStorageSqlFunc { /// /// 搜索视图 /// /// /// /// public static List SearchView(ItemStorageWebEntity 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.View_ITEMSTORAGE.OrderByDescending(x => x.id).Where(f.Compile()).Skip((page - 1) * onePageNum).Take(onePageNum).ToList(); return list; } } /// /// 搜索视图数量 /// /// /// /// public static int SearchViewNum(ItemStorageWebEntity webEntity,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)); } } } int num = edm.View_ITEMSTORAGE.Where(f.Compile()).Count(); return num; } } /// /// 首页滚动 /// /// /// /// public static List SearchViewIndex(out string msg) { msg = ""; List list=new List(); using (Model edm = new Model()) { List storageList = edm.View_ITEMSTORAGE.Where(x => x.isLessDay == "是" || x.isOverDay == "是" || x.isMoreDay=="是").ToList(); //List result = new List(); foreach (var i in storageList) { //result.Add("零件号:" + i.itemName + " 零件名称:" + i.itemDes + "超限,目前存在" + i.itemNum + " 设置上限:" + i.maxStorage + " 下限:" + i.minStorage); ReturnItemStorageEntity entity = new ReturnItemStorageEntity() { itemName=i.itemName, itemDes=i.itemDes, itemNum=i.itemNum, maxStorage=i.maxStorage, minStorage=i.minStorage, isLessDay=i.isLessDay, isMoreDay=i.isMoreDay, isOverDay=i.isOverDay }; list.Add(entity); } return list; } } } }