| 
									
										
										
										
											2016-04-29 16:26:09 +08:00
										 |  |  |  | using System; | 
					
						
							|  |  |  |  | using System.Data.Entity; | 
					
						
							|  |  |  |  | using System.Data.Entity.Migrations; | 
					
						
							| 
									
										
										
										
											2016-10-28 19:02:02 +08:00
										 |  |  |  | using System.Data.Entity.Validation; | 
					
						
							| 
									
										
										
										
											2016-04-29 16:26:09 +08:00
										 |  |  |  | using System.Linq; | 
					
						
							|  |  |  |  | using System.Linq.Expressions; | 
					
						
							|  |  |  |  | using EntityFramework.Extensions; | 
					
						
							|  |  |  |  | using Infrastructure; | 
					
						
							| 
									
										
										
										
											2017-11-29 20:49:14 +08:00
										 |  |  |  | using OpenAuth.Repository.Interface; | 
					
						
							| 
									
										
										
										
											2016-04-29 16:26:09 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | namespace OpenAuth.Repository | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |    public  class UnitWork: IUnitWork | 
					
						
							|  |  |  |  |    { | 
					
						
							|  |  |  |  |        protected OpenAuthDBContext Context = new OpenAuthDBContext(); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |        /// <summary> | 
					
						
							|  |  |  |  |         /// 根据过滤条件,获取记录 | 
					
						
							|  |  |  |  |         /// </summary> | 
					
						
							|  |  |  |  |         /// <param name="exp">The exp.</param> | 
					
						
							| 
									
										
										
										
											2016-09-02 18:05:17 +08:00
										 |  |  |  |         public IQueryable<T> Find<T>(Expression<Func<T, bool>> exp = null) where T : class  | 
					
						
							| 
									
										
										
										
											2016-04-29 16:26:09 +08:00
										 |  |  |  |         { | 
					
						
							|  |  |  |  |             return Filter(exp); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         public bool IsExist<T>(Expression<Func<T, bool>> exp) where T : class | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             return Context.Set<T>().Any(exp); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         /// <summary> | 
					
						
							|  |  |  |  |         /// 查找单个 | 
					
						
							|  |  |  |  |         /// </summary> | 
					
						
							|  |  |  |  |         public T FindSingle<T>(Expression<Func<T, bool>> exp) where T:class  | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             return Context.Set<T>().AsNoTracking().FirstOrDefault(exp); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         /// <summary> | 
					
						
							|  |  |  |  |         /// 得到分页记录 | 
					
						
							|  |  |  |  |         /// </summary> | 
					
						
							|  |  |  |  |         /// <param name="pageindex">The pageindex.</param> | 
					
						
							|  |  |  |  |         /// <param name="pagesize">The pagesize.</param> | 
					
						
							|  |  |  |  |         /// <param name="orderby">排序,格式如:"Id"/"Id descending"</param> | 
					
						
							|  |  |  |  |         public IQueryable<T> Find<T>(int pageindex, int pagesize, string orderby = "", Expression<Func<T, bool>> exp = null) where T : class | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             if (pageindex < 1) pageindex = 1; | 
					
						
							|  |  |  |  |             if (string.IsNullOrEmpty(orderby)) | 
					
						
							|  |  |  |  |                 orderby = "Id descending"; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             return Filter(exp).OrderBy(orderby).Skip(pagesize * (pageindex - 1)).Take(pagesize); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         /// <summary> | 
					
						
							|  |  |  |  |         /// 根据过滤条件获取记录数 | 
					
						
							|  |  |  |  |         /// </summary> | 
					
						
							|  |  |  |  |         public int GetCount<T>(Expression<Func<T, bool>> exp = null) where T : class | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             return Filter(exp).Count(); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-02 18:05:17 +08:00
										 |  |  |  |         public void Add<T>(T entity) where T : Domain.Entity | 
					
						
							| 
									
										
										
										
											2016-04-29 16:26:09 +08:00
										 |  |  |  |         { | 
					
						
							| 
									
										
										
										
											2017-11-29 21:32:55 +08:00
										 |  |  |  |             if (string.IsNullOrEmpty(entity.Id)) | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 entity.Id = Guid.NewGuid().ToString(); | 
					
						
							|  |  |  |  |             } | 
					
						
							| 
									
										
										
										
											2016-04-29 16:26:09 +08:00
										 |  |  |  |             Context.Set<T>().Add(entity); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         /// <summary> | 
					
						
							|  |  |  |  |         /// 批量添加 | 
					
						
							|  |  |  |  |         /// </summary> | 
					
						
							|  |  |  |  |         /// <param name="entities">The entities.</param> | 
					
						
							| 
									
										
										
										
											2016-09-02 18:05:17 +08:00
										 |  |  |  |         public void BatchAdd<T>(T[] entities) where T : Domain.Entity | 
					
						
							| 
									
										
										
										
											2016-04-29 16:26:09 +08:00
										 |  |  |  |         { | 
					
						
							| 
									
										
										
										
											2016-09-02 18:05:17 +08:00
										 |  |  |  |             foreach (var entity in entities) | 
					
						
							|  |  |  |  |             { | 
					
						
							| 
									
										
										
										
											2017-10-11 16:19:34 +08:00
										 |  |  |  |                 entity.Id = Guid.NewGuid().ToString(); | 
					
						
							| 
									
										
										
										
											2016-09-02 18:05:17 +08:00
										 |  |  |  |             } | 
					
						
							| 
									
										
										
										
											2016-04-29 16:26:09 +08:00
										 |  |  |  |             Context.Set<T>().AddRange(entities); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         public void Update<T>(T entity) where T:class | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             var entry = this.Context.Entry(entity); | 
					
						
							|  |  |  |  |             //todo:如果状态没有任何更改,会报错 | 
					
						
							|  |  |  |  |             entry.State = EntityState.Modified; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         public void Delete<T>(T entity) where T:class | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             Context.Set<T>().Remove(entity); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         /// <summary> | 
					
						
							|  |  |  |  |         /// 按指定id更新实体,会更新整个实体 | 
					
						
							|  |  |  |  |         /// </summary> | 
					
						
							|  |  |  |  |         /// <param name="identityExp">The identity exp.</param> | 
					
						
							|  |  |  |  |         /// <param name="entity">The entity.</param> | 
					
						
							|  |  |  |  |         public void Update<T>(Expression<Func<T, object>> identityExp, T entity) where T:class | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             Context.Set<T>().AddOrUpdate(identityExp, entity); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         /// <summary> | 
					
						
							|  |  |  |  |         /// 实现按需要只更新部分更新 | 
					
						
							|  |  |  |  |         /// <para>如:Update(u =>u.Id==1,u =>new User{Name="ok"});</para> | 
					
						
							|  |  |  |  |         /// </summary> | 
					
						
							|  |  |  |  |         /// <param name="where">The where.</param> | 
					
						
							|  |  |  |  |         /// <param name="entity">The entity.</param> | 
					
						
							|  |  |  |  |         public void Update<T>(Expression<Func<T, bool>> where, Expression<Func<T, T>> entity) where T:class | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             Context.Set<T>().Where(where).Update(entity); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         public virtual void Delete<T>(Expression<Func<T, bool>> exp) where T : class | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             Context.Set<T>().Where(exp).Delete(); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         public void Save() | 
					
						
							|  |  |  |  |         { | 
					
						
							| 
									
										
										
										
											2016-10-28 19:02:02 +08:00
										 |  |  |  |             try | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 Context.SaveChanges(); | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |             catch (DbEntityValidationException e) | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 throw new Exception(e.EntityValidationErrors.First().ValidationErrors.First().ErrorMessage); | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |            | 
					
						
							| 
									
										
										
										
											2016-04-29 16:26:09 +08:00
										 |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         private IQueryable<T> Filter<T>(Expression<Func<T, bool>> exp) where T : class | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             var dbSet = Context.Set<T>().AsQueryable(); | 
					
						
							|  |  |  |  |             if (exp != null) | 
					
						
							|  |  |  |  |                 dbSet = dbSet.Where(exp); | 
					
						
							|  |  |  |  |             return dbSet; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-15 17:36:41 +08:00
										 |  |  |  |        public void ExecuteSql(string sql) | 
					
						
							|  |  |  |  |        { | 
					
						
							|  |  |  |  |             Context.Database.ExecuteSqlCommand(sql); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-29 16:26:09 +08:00
										 |  |  |  |     } | 
					
						
							|  |  |  |  | } |