记录Entity Framework导致的任何出现错误的最佳做法是什么?
目前我正在使用log4net,但我认为这与日志框架无关。
关于示例API:
public class TestController : ApiController
{
[HttpGet]
public IEnumerable<Test> GetTests()
{
using(var context = new DatabaseContext())
{
return context.Tests.Where(w=>w.Enabled).ToList();
}
}
}
现在,我必须将我的方法体粘贴在try / catch中(我必须将所有控制器的所有方法体都粘贴在try / catch块中)
try
{
using (var context = new DatabaseContext())
{
return context.Tests.Where(w=>w.Enabled).ToList();
}
}
catch(Exception e)
{
// TODO: handle also those ValidationErrors, thrown by Entity Framework
// so here we get a lot more code
_logger.Error(e);
}
但是我不想把我的API的任何方法体放在try / catch块中。
是否有可能在OnException
类中添加DatabaseContext
,我总是可以记录Entity Framework抛出的任何异常?
答案 0 :(得分:2)