public static void RunPgSqlTransaction(string myConnString) {
using (PgSqlConnection pgConnection = new PgSqlConnection(myConnString)) {
pgConnection.Open();
// Start a local transaction
PgSqlTransaction myTrans = pgConnection.BeginTransaction(System.Data.IsolationLevel.ReadCommitted);
PgSqlCommand pgCommand = pgConnection.CreateCommand();
try {
pgCommand.CommandText = "INSERT INTO Dept(DeptNo, DName) Values(52, 'DEVELOPMENT')";
pgCommand.ExecuteNonQuery();
pgCommand.CommandText = "INSERT INTO Dept(DeptNo, DName) Values(62, 'PRODUCTION')";
pgCommand.ExecuteNonQuery();
myTrans.Commit();
Console.WriteLine("Both records are written to database.");
}
catch (Exception e) {
myTrans.Rollback();
Console.WriteLine(e.ToString());
Console.WriteLine("Neither record was written to database.");
}
finally {
pgCommand.Dispose();
myTrans.Dispose();
}
}
}