<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
		<id>http://www.nfex.ru/index.php?action=history&amp;feed=atom&amp;title=Csharp%2FC_Sharp%2FDatabase_ADO.net%2FTransactions</id>
		<title>Csharp/C Sharp/Database ADO.net/Transactions - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://www.nfex.ru/index.php?action=history&amp;feed=atom&amp;title=Csharp%2FC_Sharp%2FDatabase_ADO.net%2FTransactions"/>
		<link rel="alternate" type="text/html" href="http://www.nfex.ru/index.php?title=Csharp/C_Sharp/Database_ADO.net/Transactions&amp;action=history"/>
		<updated>2026-04-13T22:14:41Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://www.nfex.ru/index.php?title=Csharp/C_Sharp/Database_ADO.net/Transactions&amp;diff=913&amp;oldid=prev</id>
		<title> в 15:31, 26 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://www.nfex.ru/index.php?title=Csharp/C_Sharp/Database_ADO.net/Transactions&amp;diff=913&amp;oldid=prev"/>
				<updated>2010-05-26T15:31:19Z</updated>
		
		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr style=&quot;vertical-align: top;&quot; lang=&quot;ru&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;← Предыдущая&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;Версия 15:31, 26 мая 2010&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; style=&quot;text-align: center;&quot; lang=&quot;ru&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(нет различий)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
			</entry>

	<entry>
		<id>http://www.nfex.ru/index.php?title=Csharp/C_Sharp/Database_ADO.net/Transactions&amp;diff=914&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://www.nfex.ru/index.php?title=Csharp/C_Sharp/Database_ADO.net/Transactions&amp;diff=914&amp;oldid=prev"/>
				<updated>2010-05-26T11:42:21Z</updated>
		
		<summary type="html">&lt;p&gt;1 версия&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Новая страница&lt;/b&gt;&lt;/p&gt;&lt;div&gt;==Commit two delete sql command==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt;&lt;br /&gt;
using System;&lt;br /&gt;
using System.Data;&lt;br /&gt;
using System.Data.SqlClient;&lt;br /&gt;
   class SqlDemo {&lt;br /&gt;
      static void Main(){&lt;br /&gt;
         string connString = &amp;quot;server=(local)\\SQLEXPRESS;database=MyDatabase;Integrated Security=SSPI&amp;quot;;&lt;br /&gt;
         SqlConnection cn = new SqlConnection(connString);&lt;br /&gt;
         cn.Open();&lt;br /&gt;
         SqlTransaction objTrans = cn.BeginTransaction();&lt;br /&gt;
         try{&lt;br /&gt;
            SqlCommand cmd = cn.CreateCommand();&lt;br /&gt;
            cmd.rumandType = CommandType.Text;&lt;br /&gt;
            cmd.Transaction = objTrans;&lt;br /&gt;
            cmd.rumandText = &amp;quot;DELETE Employee WHERE Id = 222&amp;quot;;&lt;br /&gt;
            cmd.ExecuteNonQuery();&lt;br /&gt;
            cmd.rumandText=&amp;quot;DELETE Employee WHERE Id = 333&amp;quot;;&lt;br /&gt;
            cmd.ExecuteNonQuery();&lt;br /&gt;
            objTrans.rumit();&lt;br /&gt;
            Console.WriteLine(&amp;quot;Transaction Committed\n&amp;quot;);&lt;br /&gt;
         }&lt;br /&gt;
         catch (System.Data.SqlClient.SqlException  ex)&lt;br /&gt;
         {&lt;br /&gt;
            objTrans.Rollback();  &lt;br /&gt;
            Console.WriteLine(&amp;quot;Error - TRANSACTION ROLLED BACK\n&amp;quot; + ex.Message);&lt;br /&gt;
         }&lt;br /&gt;
         catch (System.Exception ex)&lt;br /&gt;
         {&lt;br /&gt;
            Console.WriteLine(&amp;quot;System Error\n&amp;quot; + ex.Message);&lt;br /&gt;
         }&lt;br /&gt;
         finally&lt;br /&gt;
         {&lt;br /&gt;
            cn.Close();  &lt;br /&gt;
         }&lt;br /&gt;
      }&lt;br /&gt;
   }&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==illustrates the use of transactions==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt;&lt;br /&gt;
/*&lt;br /&gt;
Mastering Visual C# .NET&lt;br /&gt;
by Jason Price, Mike Gunderloy&lt;br /&gt;
Publisher: Sybex;&lt;br /&gt;
ISBN: 0782129110&lt;br /&gt;
*/&lt;br /&gt;
/*&lt;br /&gt;
  Example23_4.cs illustrates the use of transactions&lt;br /&gt;
*/&lt;br /&gt;
using System;&lt;br /&gt;
using System.Data;&lt;br /&gt;
using System.Data.SqlClient;&lt;br /&gt;
public class Example23_4&lt;br /&gt;
{&lt;br /&gt;
  public static void Main()&lt;br /&gt;
  {&lt;br /&gt;
    // formulate a string containing the details of the&lt;br /&gt;
    // database connection&lt;br /&gt;
    string connectionString =&lt;br /&gt;
      &amp;quot;server=localhost;database=Northwind;uid=sa;pwd=sa&amp;quot;;&lt;br /&gt;
    // create a SqlConnection object to connect to the&lt;br /&gt;
    // database, passing the connection string to the constructor&lt;br /&gt;
    SqlConnection mySqlConnection =&lt;br /&gt;
      new SqlConnection(connectionString);&lt;br /&gt;
    // open the database connection using the&lt;br /&gt;
    // Open() method of the SqlConnection object&lt;br /&gt;
    mySqlConnection.Open();&lt;br /&gt;
    // step 1: create a SqlTransaction object and start the transaction&lt;br /&gt;
    // by calling the BeginTransaction() method of the SqlConnection&lt;br /&gt;
    // object&lt;br /&gt;
    SqlTransaction mySqlTransaction =&lt;br /&gt;
      mySqlConnection.BeginTransaction();&lt;br /&gt;
    // step 2: create a SqlCommand object to hold a SQL statement&lt;br /&gt;
    SqlCommand mySqlCommand = mySqlConnection.CreateCommand();&lt;br /&gt;
    // step 3: set the Transaction property for the SqlCommand object&lt;br /&gt;
    mySqlCommand.Transaction = mySqlTransaction;&lt;br /&gt;
    // step 4: formulate a string containing the first INSERT statement&lt;br /&gt;
    string insertString =&lt;br /&gt;
      &amp;quot;INSERT INTO Customers (&amp;quot; +&lt;br /&gt;
      &amp;quot;  CustomerID, CompanyName, ContactName, Address&amp;quot; +&lt;br /&gt;
      &amp;quot;) VALUES (&amp;quot; +&lt;br /&gt;
      &amp;quot;  &amp;quot;T2COM&amp;quot;, &amp;quot;T2 Company&amp;quot;, &amp;quot;Jason Price&amp;quot;, &amp;quot;1 Main Street&amp;quot;&amp;quot; +&lt;br /&gt;
      &amp;quot;)&amp;quot;;&lt;br /&gt;
    // step 5: set the CommandText property of the SqlCommand object to&lt;br /&gt;
    // the INSERT string&lt;br /&gt;
    mySqlCommand.rumandText = insertString;&lt;br /&gt;
    // step 6: run the first INSERT statement&lt;br /&gt;
    Console.WriteLine(&amp;quot;Running first INSERT statement&amp;quot;);&lt;br /&gt;
    mySqlCommand.ExecuteNonQuery();&lt;br /&gt;
    // step 7: formulate a second INSERT statement&lt;br /&gt;
    insertString =&lt;br /&gt;
      &amp;quot;INSERT INTO Orders (&amp;quot; +&lt;br /&gt;
      &amp;quot;  CustomerID&amp;quot; +&lt;br /&gt;
      &amp;quot;) VALUES (&amp;quot; +&lt;br /&gt;
      &amp;quot;  &amp;quot;T2COM&amp;quot;&amp;quot; +&lt;br /&gt;
      &amp;quot;)&amp;quot;;&lt;br /&gt;
    // step 8: set the CommandText property of the SqlCommand object to&lt;br /&gt;
    // the second INSERT string&lt;br /&gt;
    mySqlCommand.rumandText = insertString;&lt;br /&gt;
    // step 9: run the second INSERT statement&lt;br /&gt;
    Console.WriteLine(&amp;quot;Running second INSERT statement&amp;quot;);&lt;br /&gt;
    mySqlCommand.ExecuteNonQuery();&lt;br /&gt;
    // step 10: commit the transaction using the Commit() method&lt;br /&gt;
    // of the SqlTransaction object&lt;br /&gt;
    Console.WriteLine(&amp;quot;Committing transaction&amp;quot;);&lt;br /&gt;
    mySqlTransaction.rumit();&lt;br /&gt;
    // close the database connection using the Close() method&lt;br /&gt;
    // of the SqlConnection object&lt;br /&gt;
    mySqlConnection.Close();&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Set a savepoint in a transaction==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt; &lt;br /&gt;
using System;&lt;br /&gt;
using System.Data;&lt;br /&gt;
using System.Data.SqlClient;&lt;br /&gt;
class Savepoint {&lt;br /&gt;
    public static void Main() {&lt;br /&gt;
        SqlConnection mySqlConnection =&lt;br /&gt;
          new SqlConnection(&lt;br /&gt;
            &amp;quot;server=localhost;database=Northwind;uid=sa;pwd=sa&amp;quot;&lt;br /&gt;
          );&lt;br /&gt;
        mySqlConnection.Open();&lt;br /&gt;
        SqlTransaction mySqlTransaction = mySqlConnection.BeginTransaction();&lt;br /&gt;
        SqlCommand mySqlCommand = mySqlConnection.CreateCommand();&lt;br /&gt;
        mySqlCommand.Transaction = mySqlTransaction;&lt;br /&gt;
        mySqlCommand.rumandText =&lt;br /&gt;
          &amp;quot;INSERT INTO Customers ( &amp;quot; +&lt;br /&gt;
          &amp;quot;  CustomerID, CompanyName &amp;quot; +&lt;br /&gt;
          &amp;quot;) VALUES ( &amp;quot; +&lt;br /&gt;
          &amp;quot;  &amp;quot;J8COM&amp;quot;, &amp;quot;J8 Company&amp;quot; &amp;quot; +&lt;br /&gt;
          &amp;quot;)&amp;quot;;&lt;br /&gt;
        int numberOfRows = mySqlCommand.ExecuteNonQuery();&lt;br /&gt;
        Console.WriteLine(&amp;quot;Number of rows inserted = &amp;quot; + numberOfRows);&lt;br /&gt;
        mySqlTransaction.Save(&amp;quot;SaveCustomer&amp;quot;);&lt;br /&gt;
        mySqlCommand.rumandText = &amp;quot;INSERT INTO Orders (CustomerID ) VALUES ( &amp;quot;J8COM&amp;quot; )&amp;quot;;&lt;br /&gt;
        numberOfRows = mySqlCommand.ExecuteNonQuery();&lt;br /&gt;
        Console.WriteLine(&amp;quot;Number of rows inserted = &amp;quot; + numberOfRows);&lt;br /&gt;
        mySqlTransaction.Rollback(&amp;quot;SaveCustomer&amp;quot;);&lt;br /&gt;
        mySqlCommand.rumandText =&lt;br /&gt;
              &amp;quot;SELECT CustomerID, CompanyName &amp;quot; +&lt;br /&gt;
              &amp;quot;FROM Customers &amp;quot; +&lt;br /&gt;
              &amp;quot;WHERE CustomerID = &amp;quot;J8COM&amp;quot;&amp;quot;;&lt;br /&gt;
        SqlDataReader mySqlDataReader = mySqlCommand.ExecuteReader();&lt;br /&gt;
        while (mySqlDataReader.Read()) {&lt;br /&gt;
            Console.WriteLine(&amp;quot;mySqlDataReader[\&amp;quot; CustomerID\&amp;quot;] = &amp;quot; +&lt;br /&gt;
              mySqlDataReader[&amp;quot;CustomerID&amp;quot;]);&lt;br /&gt;
            Console.WriteLine(&amp;quot;mySqlDataReader[\&amp;quot; CompanyName\&amp;quot;] = &amp;quot; +&lt;br /&gt;
              mySqlDataReader[&amp;quot;CompanyName&amp;quot;]);&lt;br /&gt;
        }&lt;br /&gt;
        mySqlDataReader.Close();&lt;br /&gt;
        mySqlCommand.rumandText = &amp;quot;DELETE FROM Customers WHERE CustomerID = &amp;quot;J8COM&amp;quot;&amp;quot;;&lt;br /&gt;
        numberOfRows = mySqlCommand.ExecuteNonQuery();&lt;br /&gt;
        Console.WriteLine(&amp;quot;Number of rows deleted = &amp;quot; + numberOfRows);&lt;br /&gt;
        mySqlTransaction.rumit();&lt;br /&gt;
        mySqlConnection.Close();&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Transaction roll back and commit==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt;&lt;br /&gt;
using System;&lt;br /&gt;
using System.Data;&lt;br /&gt;
using System.Data.SqlClient;&lt;br /&gt;
   class SqlDemo {&lt;br /&gt;
      static void Main(){&lt;br /&gt;
         string connString = &amp;quot;server=(local)\\SQLEXPRESS;database=MyDatabase;Integrated Security=SSPI&amp;quot;;&lt;br /&gt;
         SqlConnection cn = new SqlConnection(connString);&lt;br /&gt;
         cn.Open();&lt;br /&gt;
         SqlTransaction objTrans = cn.BeginTransaction();&lt;br /&gt;
         try &lt;br /&gt;
         {      &lt;br /&gt;
            SqlCommand cmd = cn.CreateCommand();&lt;br /&gt;
            cmd.rumandType = CommandType.Text;&lt;br /&gt;
            cmd.Transaction = objTrans;&lt;br /&gt;
            cmd.rumandText = &amp;quot;DELETE Employee WHERE Id = 222&amp;quot;;&lt;br /&gt;
            cmd.ExecuteNonQuery();&lt;br /&gt;
            objTrans.rumit();&lt;br /&gt;
        &lt;br /&gt;
            Console.WriteLine(&amp;quot;Transaction Committed\n&amp;quot; );&lt;br /&gt;
         }&lt;br /&gt;
         catch (System.Data.SqlClient.SqlException ex)&lt;br /&gt;
         {&lt;br /&gt;
            objTrans.Rollback();&lt;br /&gt;
            Console.WriteLine(&amp;quot;Error - TRANSACTION ROLLED BACK\n&amp;quot; + ex.Message);&lt;br /&gt;
         }&lt;br /&gt;
         catch (System.Exception ex)&lt;br /&gt;
         {&lt;br /&gt;
            Console.WriteLine(&amp;quot;System Error\n&amp;quot; + ex.Message);&lt;br /&gt;
         }&lt;br /&gt;
         finally&lt;br /&gt;
         {&lt;br /&gt;
            cn.Close();&lt;br /&gt;
         }&lt;br /&gt;
      }&lt;br /&gt;
   }&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Update Data Using Transactions==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt;&lt;br /&gt;
/*&lt;br /&gt;
 * C# Programmers Pocket Consultant&lt;br /&gt;
 * Author: Gregory S. MacBeth&lt;br /&gt;
 * Email: gmacbeth@comporium.net&lt;br /&gt;
 * Create Date: June 27, 2003&lt;br /&gt;
 * Last Modified Date:&lt;br /&gt;
 * Version: 1&lt;br /&gt;
 */&lt;br /&gt;
using System;&lt;br /&gt;
using System.Data;&lt;br /&gt;
using System.Data.SqlClient;&lt;br /&gt;
namespace Client.Chapter_13___ADO.NET&lt;br /&gt;
{&lt;br /&gt;
    public class UpdatingDataUsingTransactions&lt;br /&gt;
    {&lt;br /&gt;
        static void Main(string[] args)&lt;br /&gt;
        {&lt;br /&gt;
            SqlConnection MyConnection = new SqlConnection(@&amp;quot;Data Source=(local); Initial Catalog = CaseManager; Integrated Security=true&amp;quot;);&lt;br /&gt;
            MyConnection.Open();&lt;br /&gt;
            String MyString = &amp;quot;INSERT INTO Test(ID, Contact, Email)VALUES(1, &amp;quot;Greg&amp;quot;, &amp;quot;Mac&amp;quot;)&amp;quot;;&lt;br /&gt;
            SqlTransaction MyTransaction = MyConnection.BeginTransaction();&lt;br /&gt;
            SqlCommand MyCmd = new SqlCommand(MyString, MyConnection, MyTransaction);&lt;br /&gt;
            MyCmd.ExecuteScalar();&lt;br /&gt;
            MyTransaction.rumit();&lt;br /&gt;
            MyConnection.Close();&lt;br /&gt;
        }&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Use of a transaction==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt;&lt;br /&gt;
using System;&lt;br /&gt;
using System.Data;&lt;br /&gt;
using System.Data.SqlClient;&lt;br /&gt;
class ExecuteTransaction&lt;br /&gt;
{&lt;br /&gt;
  public static void Main()&lt;br /&gt;
  {&lt;br /&gt;
    SqlConnection mySqlConnection =new SqlConnection(&amp;quot;server=(local)\\SQLEXPRESS;database=MyDatabase;Integrated Security=SSPI;&amp;quot;);&lt;br /&gt;
    mySqlConnection.Open();&lt;br /&gt;
    SqlTransaction mySqlTransaction = mySqlConnection.BeginTransaction();&lt;br /&gt;
    SqlCommand mySqlCommand = mySqlConnection.CreateCommand();&lt;br /&gt;
    mySqlCommand.Transaction = mySqlTransaction;&lt;br /&gt;
    mySqlCommand.rumandText =&lt;br /&gt;
      &amp;quot;INSERT INTO Employee (&amp;quot; +&lt;br /&gt;
      &amp;quot;  ID, FirstName&amp;quot; +&lt;br /&gt;
      &amp;quot;) VALUES (&amp;quot; +&lt;br /&gt;
      &amp;quot;  10, &amp;quot;Jason&amp;quot;&amp;quot; +&lt;br /&gt;
      &amp;quot;)&amp;quot;;&lt;br /&gt;
    Console.WriteLine(&amp;quot;Running first INSERT statement&amp;quot;);&lt;br /&gt;
    mySqlCommand.ExecuteNonQuery();&lt;br /&gt;
    mySqlCommand.rumandText =&lt;br /&gt;
      &amp;quot;INSERT INTO Employee (&amp;quot; +&lt;br /&gt;
      &amp;quot;  ID, FirstName&amp;quot; +&lt;br /&gt;
      &amp;quot;) VALUES (&amp;quot; +&lt;br /&gt;
      &amp;quot;  11, &amp;quot;Jason&amp;quot;&amp;quot; +&lt;br /&gt;
      &amp;quot;)&amp;quot;;&lt;br /&gt;
    Console.WriteLine(&amp;quot;Running second INSERT statement&amp;quot;);&lt;br /&gt;
    mySqlCommand.ExecuteNonQuery();&lt;br /&gt;
    Console.WriteLine(&amp;quot;Committing transaction&amp;quot;);&lt;br /&gt;
    mySqlTransaction.rumit();&lt;br /&gt;
    mySqlConnection.Close();&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>