国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > .NET > 正文

asp.net core 實現一個簡單的倉儲的方法

2024-07-10 12:48:53
字體:
來源:轉載
供稿:網友

一直有自己寫個框架的想法,但是一直沒有行動起來,最近比較閑,正好可以開工了.

現在已經完成了兩部分.1.一個簡單倉儲,實現使用的是ef 2.IOC部分,這里是把內置的ioc替換成了aotofac,這部分感覺還是有一點缺陷的.下面說

倉儲部分

這里主要是接口是實現,目前使用ef實現了倉儲的接口.看一下代碼

 public interface IRepository<TEntity, TPrimaryKey>  where TEntity : class {  #region Select/Get/Query  IQueryable<TEntity> GetAll();  IQueryable<TEntity> GetAllIncluding(params Expression<Func<TEntity, object>>[] propertySelectors);  List<TEntity> GetAllList();  Task<List<TEntity>> GetAllListAsync();  List<TEntity> GetAllList(Expression<Func<TEntity, bool>> predicate);  Task<List<TEntity>> GetAllListAsync(Expression<Func<TEntity, bool>> predicate);  T Query<T>(Func<IQueryable<TEntity>, T> queryMethod);  TEntity Get(TPrimaryKey id);  Task<TEntity> GetAsync(TPrimaryKey id);  TEntity Single(Expression<Func<TEntity, bool>> predicate);  Task<TEntity> SingleAsync(Expression<Func<TEntity, bool>> predicate);  TEntity FirstOrDefault(TPrimaryKey id);  Task<TEntity> FirstOrDefaultAsync(TPrimaryKey id);  TEntity FirstOrDefault(Expression<Func<TEntity, bool>> predicate);  Task<TEntity> FirstOrDefaultAsync(Expression<Func<TEntity, bool>> predicate);  TEntity Load(TPrimaryKey id);  #endregion  #region Insert  TEntity Insert(TEntity entity);  Task<TEntity> InsertAsync(TEntity entity);  #endregion  #region Update  TEntity Update(TEntity entity);  Task<TEntity> UpdateAsync(TEntity entity);  TEntity Update(TPrimaryKey id, Action<TEntity> updateAction);  Task<TEntity> UpdateAsync(TPrimaryKey id, Func<TEntity, Task> updateAction);  #endregion  #region Delete  void Delete(TEntity entity);  Task DeleteAsync(TEntity entity);  void Delete(TPrimaryKey id);  Task DeleteAsync(TPrimaryKey id);  void Delete(Expression<Func<TEntity, bool>> predicate);  Task DeleteAsync(Expression<Func<TEntity, bool>> predicate);  #endregion  #region Aggregates  int Count();  Task<int> CountAsync();  int Count(Expression<Func<TEntity, bool>> predicate);  Task<int> CountAsync(Expression<Func<TEntity, bool>> predicate);  long LongCount();  Task<long> LongCountAsync();  long LongCount(Expression<Func<TEntity, bool>> predicate);  Task<long> LongCountAsync(Expression<Func<TEntity, bool>> predicate);  #endregion }

下面是實現的部分代碼,代碼比較占版面,就不貼全了.

 public abstract class RepositoryBase<TEntity, TPrimaryKey> : IRepository<TEntity, TPrimaryKey>  where TEntity : class {  public abstract IQueryable<TEntity> GetAll();  public abstract IQueryable<TEntity> GetAllIncluding(params Expression<Func<TEntity, object>>[] propertySelectors);  public virtual List<TEntity> GetAllList()  {   return GetAll().ToList();  }  public virtual async Task<List<TEntity>> GetAllListAsync()  {   return await Task.FromResult(GetAllList());  } }            
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 西吉县| 辉南县| 盐山县| 渝中区| 漯河市| 祁阳县| 嘉峪关市| 宝山区| 穆棱市| 英德市| 旬邑县| 德令哈市| 禄丰县| 东安县| 建湖县| 沙田区| 龙岩市| 麻阳| 闸北区| 资阳市| 车险| 新竹县| 宁津县| 湘阴县| 大足县| 曲靖市| 汽车| 五家渠市| 佳木斯市| 徐州市| 泾源县| 桑植县| 新沂市| 普兰县| 临海市| 双牌县| 沅江市| 金溪县| 洛宁县| 大田县| 乐清市|