| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129 |
- //
- // System.Data.SqlClient.SqlTransaction.cs
- //
- // Author:
- // Tim Coleman ([email protected])
- //
- // Copyright (C) Tim Coleman, 2002
- //
- using Mono.Data.TdsClient;
- using System;
- using System.Data;
- using System.Data.Common;
- namespace System.Data.SqlClient {
- public sealed class SqlTransaction : MarshalByRefObject, IDbTransaction, IDisposable
- {
- #region Fields
- SqlConnection connection;
- IsolationLevel isolationLevel;
- bool isOpen;
- #endregion
- #region Constructors
- internal SqlTransaction (SqlConnection connection, IsolationLevel isolevel)
- {
- SetIsolationLevel (connection, isolevel);
- this.connection = connection;
- this.isolationLevel = isolevel;
- isOpen = true;
- }
- #endregion // Constructors
- #region Properties
- public SqlConnection Connection {
- get { return connection; }
- }
- internal bool IsOpen {
- get { return isOpen; }
- }
- public IsolationLevel IsolationLevel {
- get { return isolationLevel; }
- }
-
- IDbConnection IDbTransaction.Connection {
- get { return Connection; }
- }
- #endregion // Properties
-
- #region Methods
- static void SetIsolationLevel (SqlConnection connection, IsolationLevel isolevel)
- {
- string commandText = "SET TRANSACTION ISOLATION LEVEL ";
- switch (isolevel) {
- case IsolationLevel.Chaos :
- commandText += "CHAOS";
- break;
- case IsolationLevel.ReadCommitted :
- commandText += "READ COMMITTED";
- break;
- case IsolationLevel.ReadUncommitted :
- commandText += "READ UNCOMMITTED";
- break;
- case IsolationLevel.RepeatableRead :
- commandText += "REPEATABLE READ";
- break;
- case IsolationLevel.Serializable :
- commandText += "SERIALIZABLE";
- break;
- default :
- return;
- }
- connection.Tds.ExecuteNonQuery (commandText);
- connection.CheckForErrors ();
- }
- public void Commit ()
- {
- if (!isOpen)
- throw new InvalidOperationException ("The Transaction was not open.");
- connection.Tds.ExecuteNonQuery ("IF @@TRANCOUNT>0 COMMIT TRAN");
- isOpen = false;
- }
- [MonoTODO]
- public void Dispose ()
- {
- throw new NotImplementedException ();
- }
- public void Rollback ()
- {
- if (!isOpen)
- throw new InvalidOperationException ("The Transaction was not open.");
- connection.Tds.ExecuteNonQuery ("IF @@TRANCOUNT>0 ROLLBACK TRAN");
- connection.CheckForErrors ();
- isOpen = false;
- }
- public void Rollback (string transactionName)
- {
- if (!isOpen)
- throw new InvalidOperationException ("The Transaction was not open.");
- connection.Tds.ExecuteNonQuery (String.Format ("IF @@TRANCOUNT > 0 ROLLBACK TRAN {0}", transactionName));
- connection.CheckForErrors ();
- isOpen = false;
- }
- public void Save (string savePointName)
- {
- if (!isOpen)
- throw new InvalidOperationException ("The Transaction was not open.");
- connection.Tds.ExecuteNonQuery (String.Format ("SAVE TRAN {0}", savePointName));
- connection.CheckForErrors ();
- }
- #endregion // Methods
- }
- }
|