I moved all my DBContext call in the repositories.
public class PayAllowanceRepository
{
private static DBEntities _dbContext = new DBEntities();
public static void AddAllowance(Allowance payAllowance)
{
_dbContext.Allowances.Add(payAllowance);
_dbContext.SaveChanges();
}
public static void AddAllowanceAccumulators(List<Allowance> allowanceList)
{
_dbContext = new DBEntities();
_dbContext.Allowances.AddRange(allowanceList);
allowanceList.ForEach(p => _dbContext.Entry(p).State = System.Data.Entity.EntityState.Modified);
_dbContext.SaveChanges();
}
// Here
public static void AddAllowanceAccumulatorsHours(List<Allowance> allowanceListHours)
{
_dbContext = new DBEntities();
_dbContext.Allowances.AddRange(allowanceListHours);
allowanceListHours.ForEach(x => _dbContext.Entry(x).State = System.Data.Entity.EntityState.Modified);
_dbContext.SaveChanges();
}
public static void UpdateAllowance(Allowance payAllowance)
{
_dbContext=new DBEntities();
_dbContext.Entry(payAllowance).State = System.Data.Entity.EntityState.Modified;
_dbContext.SaveChanges();
}
public static void DeleteAllowance(Guid id)
{
var allowance = _dbContext.Allowances.FirstOrDefault(x => x.Id == id);
_dbContext.Allowances.Remove(allowance);
_dbContext.SaveChanges();
}
public static void UpdateAllowanceRate(Allowance allowanceRate)
{
//dbContext.Allowances.Add(allowanceRate);
_dbContext.Entry(allowanceRate).State = System.Data.Entity.EntityState.Modified;
_dbContext.SaveChanges();
}
public static List<Allowance> GetAllowances(Guid payrollCompanyId)
{
var allowance = new List<Allowance>(_dbContext.Allowances.AsNoTracking().Where(x => x.PayrollCompanyId == payrollCompanyId));
return allowance;
}
}
- Is this the best way to tackle the DBContext in repositories?
- It is failing when executing AddAllowanceAccumulatorsHours. I get error message : An entity object cannot be referenced by multiple instances of IEntityChangeTracker. What I am doing wrong?