I have question regarding Entity Framework. In my program I first fill-up my DbContext with data. Then I need to delete all the data from the tables in DB, but only if new data will be saved. If db.Savechanges() throws an exception I need my old data to still be in the tables.
My code is:
static void Main(string[] args)
{
PdmContext db = new PdmContext();
FillDbContext();
try
{
if (db.SaveChanges() > 0)
{
using (var del = new PdmContext())
{
DeleteModel.deleteFromAllTables();
}
db.SaveChanges();
}
}
catch (Exception exp)
{
Logger.Log("Exception (global catch));
}
}
I can't seem to figure this out. Anyone can help with this? :)
DeleteModel.deleteFromAllTables()do? And why do you need two instances ofPdmContext? If you're deleting your data in a separate transaction and committing that transaction then that would certainly explain why that transaction is being committed. EF won't commit a transaction if an exception is thrown, so it seems that you're committing your deletes yourself somewhere.