using IWareDataAccess.EF; using IWareDataAccess.Entity.Sys; using IWareDataAccess.Helper; using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace IWareDataAccess.Sys.ROLE { public static class RoleSqlFunc { /// /// 搜索(表) /// /// /// /// public static List Search(RoleWebEntity 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 (i.PropertyType == typeof(DateTime?)) { if (v != null) { DateTime value = DateTime.Parse(v.ToString()); if (i.Name == "updateTimeStart") { f = f.And(x => x.UPDATETIME > value); } if (i.Name == "updateTimeEnd") { f = f.And(x => x.UPDATETIME < value); } } } else { if (v != null) { f = f.And(x => Object.Equals(Helper.Helper.GetFieldValueByName(x, i.Name), v)); } } } List list = edm.SYS_ROLE.Where(f.Compile()).Skip((page - 1) * onePageNum).Take(onePageNum).ToList(); return list; } } /// /// 搜索(视图) /// /// /// /// public static List SearchView(RoleWebEntity 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 (i.PropertyType == typeof(DateTime?)) { if (v != null) { DateTime value = DateTime.Parse(v.ToString()); if (i.Name == "updateTimeStart") { f = f.And(x => x.updateTime > value); } if (i.Name == "updateTimeEnd") { f = f.And(x => x.updateTime < value); } } } else { if (v != null) { f = f.And(x => Object.Equals(Helper.Helper.GetFieldValueByName(x, i.Name), v)); } } } List list = edm.View_SYS_ROLE.Where(f.Compile()).Skip((page - 1) * onePageNum).Take(onePageNum).ToList(); return list; } } /// /// 搜索(视图) /// /// /// /// public static int SearchViewNum(RoleWebEntity 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.View_SYS_ROLE.Where(f.Compile()).Count(); return num; } } /// /// 添加权限 /// /// /// public static bool AddOrUpdate(RoleWebEntity webRole, out string msg) { msg = ""; using (Model edm = new Model()) { Dictionary dic = new Dictionary(); //查询是否已存在此权限 SYS_ROLE role = edm.SYS_ROLE.FirstOrDefault(x => x.ROLENAME == webRole.roleName); if (role == null) { //无此角色,属于新建 role = new SYS_ROLE(); } role.ROLENAME= webRole.roleName??role.ROLENAME; role.ENABLE= webRole.enable?? role.ENABLE; SYS_USER user = edm.SYS_USER.FirstOrDefault(x => x.USERNAME == webRole.userName); if (user != null) { role.CREATORID = user.ID; } else { role.CREATORID = 1; } role.UPDATETIME = DateTime.Now; edm.SYS_ROLE.AddOrUpdateExtension(role); if (edm.SaveChanges() > 0) { return true; } else { msg = "修改失败"; return false; } } } /// /// 删除权限 /// /// /// public static bool Delete(RoleWebEntity webRole,out string msg) { msg = ""; using (Model edm = new Model()) { Dictionary dic = new Dictionary(); //查询是否已存在此权限 SYS_ROLE role = edm.SYS_ROLE.FirstOrDefault(x => x.ROLENAME == webRole.roleName); if (role == null) { //无此角色 msg = "无此角色"; return false; } else { return DeleteRoleRelevance(role,out msg); } } } /// /// 关联删除 /// /// /// public static bool DeleteRoleRelevance(SYS_ROLE role,out string msg) { msg = ""; using (Model edm = new Model()) { //因已释放连接,故重新指向数据库对象进行索引 SYS_ROLE roleDelete = edm.SYS_ROLE.FirstOrDefault(x => x.ROLENAME == role.ROLENAME); ////删除角色关系 //edm.SYS_USER_VS_ROLE.RemoveRange(roleDelete.SYS_USER_VS_ROLE); //edm.SYS_ROLE_VS_PERMISSION.RemoveRange(roleDelete.SYS_ROLE_VS_PERMISSION); //删除角色 //edm.SYS_ROLE.Remove(roleDelete); roleDelete.ENABLE = 0; if (edm.SaveChanges() > 0) { return true; } else { msg = "删除失败"; return false; } } } } }