我的代码中出现错误
在提供程序连接上启动事务时发生错误。有关详细信息,请参阅内部异常
内部例外是:
不允许使用新事务,因为会话中还有其他线程在运行。
我的代码:
using (var db = new ProductionContext())
{
var objct = ((System.Data.Entity.Infrastructure.IObjectContextAdapter)db).ObjectContext;
objct.ExecuteStoreCommand("TRUNCATE TABLE [MU By Machine]");
db.SaveChanges();
var query =
db.MU_Reports
.GroupBy(x => new { x.Date, x.Machine_Number, x.Shift })
.Select(x => new
{
Date = x.Key.Date,
Shift = x.Key.Shift,
MachineNum = x.Key.Machine_Number,
MU = x.Sum(i => i.MU * 100)
});
foreach (var item in query)
{
var y = new MU_By_Machine();
y.Date = item.Date;
y.Shift = item.Shift;
y.Machine_Number = item.MachineNum;
y.MU = item.MU;
db.MU_By_Machines.Add(y);
db.SaveChanges();
}
它发生在我的代码的db.SaveChanges
部分,当我将它移出for循环时,代码可以工作但只能在我的表中保存一行。如果需要其他信息,请通知我。我还是c#的新手。
答案 0 :(得分:2)
替换
var query = db.MU_Reports
.GroupBy(x => new { x.Date, x.Machine_Number, x.Shift })
.Select(x => new
{
Date = x.Key.Date,
Shift = x.Key.Shift,
MachineNum = x.Key.Machine_Number,
MU = x.Sum(i => i.MU * 100)
});
带
var query = db.MU_Reports
.GroupBy(x => new { x.Date, x.Machine_Number, x.Shift })
.Select(x => new
{
Date = x.Key.Date,
Shift = x.Key.Shift,
MachineNum = x.Key.Machine_Number,
MU = x.Sum(i => i.MU * 100)
}).ToList();
它帮助我解决了类似的问题。在不使用.ToList()方法循环查询结果时会发生此错误。此方法关闭连接并避免此问题。