(仓储模式)ASP.NET Core用EF Core用的是Microsoft.EntityFrameworkCore.SqlServer 2.0.3版本

方式一:

using MatrixWebApiCore.Entity;
using Microsoft.EntityFrameworkCore;
using System; 
using System.Linq; 

namespace MatrixWebApiCore.Common.Data
{
    public class DataContext : DbContext
    {

        public DataContext(DbContextOptions options)
      : base(options)
        { }
 
        /// 
        /// 报告实体,执行增删改查用
        /// 
        public virtual DbSet GroupCharts { get; set; }
        public virtual DbSet CombinationGroupCharts { get; set; }
        /// 
        /// 异常日志
        /// 
        public virtual DbSet Log { get; set; }        
    }   
}

using MatrixWebApiCore.Entity;
using Microsoft.EntityFrameworkCore;
using System;
using System.Collections.Generic;
using System.Data.SqlClient;
using System.Linq;
using System.Linq.Expressions;

namespace MatrixWebApiCore.Common.Data
{
    public class RepositoryBase : IRepository where T : BaseEntity, new()
    {
        private DataContext dbContext;
        private DbSet dbSet;
        public RepositoryBase(DataContext _dbContext)
        {
            dbContext = _dbContext;
            dbSet = dbContext.Set();
        } 

        public int Add(T entity)
        {
            dbSet.Add(entity);
            return dbContext.SaveChanges();
        }

        public int Add(IEnumerable entitys)
        {
            foreach (var entity in entitys)
            {
                dbSet.Add(entity);
            }
            return dbContext.SaveChanges();
        }

        public int Update(T entity)
        {
            dbSet.Attach(entity);
            dbContext.Entry(entity).State = EntityState.Modified;
            return dbContext.SaveChanges();
        }

        public int Update(IEnumerable entitys)
        {
            foreach (var entity in entitys)
            {
                dbSet.Attach(entity);
                dbContext.Entry(entity).State = EntityState.Modified;
            }
            return dbContext.SaveChanges();
        }

        public int Delete(T entity)
        {
            dbSet.Attach(entity);
            dbSet.Remove(entity);
            return dbContext.SaveChanges();
        }
       

        public int Delete(Expression> where)
        {
            var entitys = this.GetList(where);
            foreach (var entity in entitys)
            {
                dbSet.Remove(entity);
            }
            return dbContext.SaveChanges();
        }
        public T Get(Expression> where)
        {
            return dbSet.Where(where).FirstOrDefault();
        }

        public IQueryable GetList(Expression> where)
        {
            return dbSet.Where(where);
        }

        public IQueryable GetQuery()
        {
            return dbSet;
        }

        public IQueryable GetQuery(Expression> where)
        {
            return dbSet.Where(where);
        }
   
        public IQueryable GetAll()
        {
            return dbSet.AsParallel().AsQueryable();
            //return dbSet.AsQueryable();
        }

        public T GetAsNoTracking(Expression> where)
        {
            return dbSet.Where(where).AsNoTracking().FirstOrDefault();
        }

        public IQueryable GetManyAsNoTracking(Expression> where)
        {
            return dbSet.AsNoTracking().Where(where);
        }

        public IQueryable GetAllAsNoTracking()
        {
            return dbSet.AsNoTracking();
        }

        public bool Any(Expression> @where)
        {
            return dbSet.Any(where);
        }

        public int Count(Expression> @where)
        {
            return dbSet.Count(where);
        }
       

    }
}

using System;
using System.Collections.Generic;
using System.Linq;
using System.Linq.Expressions;

namespace MatrixWebApiCore.Common.Data
{

    public interface IRepository where T : class
    {   
        int Add(T entity);
        int Add(IEnumerable entitys);
        int Update(T entity);
        int Delete(T entity);       
        int Delete(Expression> where);
        T Get(Expression> where);
        IQueryable GetList(Expression> where);
        IQueryable GetQuery(); 
        IQueryable GetQuery(Expression> where);        
        IQueryable GetAll();
        T GetAsNoTracking(Expression> where);
        IQueryable GetManyAsNoTracking(Expression> where);       
        IQueryable GetAllAsNoTracking();

        /// 
        /// 检查是否存在
        /// 
        /// 
        /// 
        bool Any(Expression> where);
        int Count(Expression> where);
 
    }
}

public interface IGroupChartsRepository :  IRepository
{ 
}

public class GroupChartsRepository : RepositoryBase, IGroupChartsRepository
{
	public GroupChartsRepository(DataContext db) : base(db)
	{ }
}


[Produces("application/json")]
[Route("api/[controller]")]
public class ChartDataController : Controller
{
	private IGroupChartsRepository _group;

	public ChartDataController(IGroupChartsRepository group)
	{
		_group = group;		 
	}
	
    [HttpPost("Delete")]
	public async Task DeleteSavedReport([FromBody]BaseRequest parames)
	{
	  return await Task.Run(() =>
		{
			_group.Delete(w => w.Id == parames.Guid);
		}
	}
	
}	




在Startup.cs注册服务


public void ConfigureServices(IServiceCollection services)
{
	string sqlConnection ="连接字符串";
	services.AddDbContext(option => option.UseSqlServer(sqlConnection));

	services.AddScoped();	
	//services.AddScoped(); 
	//services.AddSingleton();
	services.BuildServiceProvider();          

	//支持跨域
	services.AddCors();
	//注册内存缓存
	services.AddMemoryCache();
	//services.AddResponseCaching();
	services.AddMvcCore(options =>
	{
	//全局异常过滤器
	options.Filters.Add();
	//options.CacheProfiles.Add("test1", new CacheProfile());
	})
	//services.AddMvc()
	.AddJsonFormatters()//配置返回json格式数据,不然会报错
	.AddApiExplorer()
	//全局配置Json序列化处理
	.AddJsonOptions(options =>
	{
		//忽略循环引用
		options.SerializerSettings.ReferenceLoopHandling = ReferenceLoopHandling.Ignore;
		//不使用驼峰样式的key
		options.SerializerSettings.ContractResolver = new DefaultContractResolver();
		//设置时间格式
		options.SerializerSettings.DateFormatString = "yyyy-MM-dd HH:mm:ss";
	});
}

方式二
DataContext有区别,Repository有区别,然后是Startup.cs里面不用写这行代码:

services.AddDbContext(option => option.UseSqlServer(sqlConnection));

其他的写法和上面一模一样,这个注册服务要写:

services.AddScoped();
using MatrixWebApiCore.Entity;
using Microsoft.EntityFrameworkCore;
using System; 
using System.Linq; 

namespace MatrixWebApiCore.Common.Data
{
    public class DataContext : DbContext
    {  

        protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
        {
            optionsBuilder.UseSqlServer("连接字符串");
            //optionsBuilder.UseSqlServer(@"Server=(localdb)\mssqllocaldb;Database=Blogging;Trusted_Connection=True;");
        }

        /// 
        /// 报告实体,执行增删改查用
        /// 
        public virtual DbSet GroupCharts { get; set; }
        public virtual DbSet CombinationGroupCharts { get; set; }
        /// 
        /// 异常日志
        /// 
        public virtual DbSet Log { get; set; }        
    }   
}

using System;
using System.Collections.Generic;
using System.Linq;
using System.Linq.Expressions;

namespace MatrixWebApiCore.Common.Data
{

    public interface IRepository where T : class
    {
        DataContext GetDataContext { get; }
        int Add(T entity);
        int Add(IEnumerable entitys);
        int Update(T entity);
        int Delete(T entity);       
        int Delete(Expression> where);
        T Get(Expression> where);
        IQueryable GetList(Expression> where);
        IQueryable GetQuery(); 
        IQueryable GetQuery(Expression> where);        
        IQueryable GetAll();
        T GetAsNoTracking(Expression> where);
        IQueryable GetManyAsNoTracking(Expression> where);       
        IQueryable GetAllAsNoTracking();

        /// 
        /// 检查是否存在
        /// 
        /// 
        /// 
        bool Any(Expression> where);
        int Count(Expression> where);
 
    }
}

using MatrixWebApiCore.Entity;
using Microsoft.EntityFrameworkCore;
using System;
using System.Collections.Generic;
using System.Data.SqlClient;
using System.Linq;
using System.Linq.Expressions;

namespace MatrixWebApiCore.Common.Data
{
    public class RepositoryBase : IRepository where T : BaseEntity, new()
    { 
        private DataContext dbContext;
        private DbSet dbSet;

        public DataContext GetDataContext { get { return dbContext; } }

        public RepositoryBase()
        {
            dbContext = new DataContext();
            dbSet = dbContext.Set();
        }

        public int Add(T entity)
        {
            dbSet.Add(entity);
            return dbContext.SaveChanges();
        }

        public int Add(IEnumerable entitys)
        {
            foreach (var entity in entitys)
            {
                dbSet.Add(entity);
            }
            return dbContext.SaveChanges();
        }

        public int Update(T entity)
        {
            dbSet.Attach(entity);
            dbContext.Entry(entity).State = EntityState.Modified;
            return dbContext.SaveChanges();
        }

        public int Update(IEnumerable entitys)
        {
            foreach (var entity in entitys)
            {
                dbSet.Attach(entity);
                dbContext.Entry(entity).State = EntityState.Modified;
            }
            return dbContext.SaveChanges();
        }

        public int Delete(T entity)
        {
            dbSet.Attach(entity);
            dbSet.Remove(entity);
            return dbContext.SaveChanges();
        }
 

        public int Delete(Expression> where)
        {
            var entitys = this.GetList(where);
            foreach (var entity in entitys)
            {
                dbSet.Remove(entity);
            }
            return dbContext.SaveChanges();
        }
        public T Get(Expression> where)
        {
            return dbSet.Where(where).FirstOrDefault();
        }

        public IQueryable GetList(Expression> where)
        {
            return dbSet.Where(where);
        }

        public IQueryable GetQuery()
        {
            return dbSet;
        }

        public IQueryable GetQuery(Expression> where)
        {
            return dbSet.Where(where);
        }
    
        public IQueryable GetAll()
        {
            return dbSet.AsParallel().AsQueryable();
            //return dbSet.AsQueryable();
        }

        public T GetAsNoTracking(Expression> where)
        {
            return dbSet.Where(where).AsNoTracking().FirstOrDefault();
        }

        public IQueryable GetManyAsNoTracking(Expression> where)
        {
            return dbSet.AsNoTracking().Where(where);
        }

        public IQueryable GetAllAsNoTracking()
        {
            return dbSet.AsNoTracking();
        }

        public bool Any(Expression> @where)
        {
            return dbSet.Any(where);
        }

        public int Count(Expression> @where)
        {
            return dbSet.Count(where);
        }

    }
}

public class GroupChartsRepository : RepositoryBase, IGroupChartsRepository
{       
}

你可能感兴趣的:(EF,Core,C#)