方式一:
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
{
}