<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
		<id>http://nfex.ru/index.php?action=history&amp;feed=atom&amp;title=Visual_C%2B%2B_.NET%2FDatabase_ADO.net%2FTransaction</id>
		<title>Visual C++ .NET/Database ADO.net/Transaction - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://nfex.ru/index.php?action=history&amp;feed=atom&amp;title=Visual_C%2B%2B_.NET%2FDatabase_ADO.net%2FTransaction"/>
		<link rel="alternate" type="text/html" href="http://nfex.ru/index.php?title=Visual_C%2B%2B_.NET/Database_ADO.net/Transaction&amp;action=history"/>
		<updated>2026-04-30T21:02:34Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://nfex.ru/index.php?title=Visual_C%2B%2B_.NET/Database_ADO.net/Transaction&amp;diff=3858&amp;oldid=prev</id>
		<title> в 15:31, 26 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://nfex.ru/index.php?title=Visual_C%2B%2B_.NET/Database_ADO.net/Transaction&amp;diff=3858&amp;oldid=prev"/>
				<updated>2010-05-26T15:31:02Z</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://nfex.ru/index.php?title=Visual_C%2B%2B_.NET/Database_ADO.net/Transaction&amp;diff=3859&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://nfex.ru/index.php?title=Visual_C%2B%2B_.NET/Database_ADO.net/Transaction&amp;diff=3859&amp;oldid=prev"/>
				<updated>2010-05-26T12:06: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;==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;
#include &amp;quot;stdafx.h&amp;quot;&lt;br /&gt;
using namespace System;&lt;br /&gt;
using namespace System::Data;&lt;br /&gt;
using namespace System::Data::SqlClient;&lt;br /&gt;
using namespace System::Configuration;&lt;br /&gt;
void main(){&lt;br /&gt;
    String ^Name = &amp;quot;Doors&amp;quot;;&lt;br /&gt;
    SqlConnection  ^connection = gcnew SqlConnection();&lt;br /&gt;
    SqlTransaction ^transaction;&lt;br /&gt;
    connection-&amp;gt;ConnectionString = &amp;quot;SQLConnection&amp;quot;;&lt;br /&gt;
    try{&lt;br /&gt;
       connection-&amp;gt;Open();&lt;br /&gt;
       SqlCommand ^cmd = gcnew SqlCommand();&lt;br /&gt;
       transaction = connection-&amp;gt;BeginTransaction(IsolationLevel::Serializable, &amp;quot;AuthorTransaction&amp;quot;);&lt;br /&gt;
       cmd-&amp;gt;Connection  = connection;&lt;br /&gt;
       cmd-&amp;gt;Transaction = transaction;&lt;br /&gt;
       cmd-&amp;gt;CommandType = CommandType::StoredProcedure;&lt;br /&gt;
       cmd-&amp;gt;CommandText = &amp;quot;InsertAuthor&amp;quot;;&lt;br /&gt;
       cmd-&amp;gt;Parameters-&amp;gt;Add(gcnew SqlParameter(&amp;quot;@LastName&amp;quot;, SqlDbType::Char,32));&lt;br /&gt;
       cmd-&amp;gt;Parameters-&amp;gt;Add(gcnew SqlParameter(&amp;quot;@FirstName&amp;quot;,SqlDbType::Char,32));&lt;br /&gt;
       cmd-&amp;gt;Parameters[&amp;quot;@LastName&amp;quot;]-&amp;gt;Value  = &amp;quot;Dope&amp;quot;;&lt;br /&gt;
       cmd-&amp;gt;Parameters[&amp;quot;@FirstName&amp;quot;]-&amp;gt;Value = &amp;quot;John&amp;quot;;&lt;br /&gt;
       int affected = cmd-&amp;gt;ExecuteNonQuery();&lt;br /&gt;
       if (affected &amp;lt;= 0)&lt;br /&gt;
           throw gcnew Exception(&amp;quot;Insert Failed&amp;quot;);&lt;br /&gt;
       Console::WriteLine(&amp;quot;Insert - {0} rows are affected&amp;quot;, affected);&lt;br /&gt;
       cmd-&amp;gt;CommandType = CommandType::Text;&lt;br /&gt;
       cmd-&amp;gt;CommandText = &amp;quot;UPDATE Authors SET LastName = &amp;quot;Doe&amp;quot; WHERE LastName = &amp;quot;Dope&amp;quot;&amp;quot;;&lt;br /&gt;
       affected = cmd-&amp;gt;ExecuteNonQuery();&lt;br /&gt;
       if (affected &amp;lt;= 0)&lt;br /&gt;
           throw gcnew Exception(&amp;quot;Insert Failed&amp;quot;);&lt;br /&gt;
       Console::WriteLine(&amp;quot;Update - {0} rows are affected&amp;quot;, affected);&lt;br /&gt;
       cmd-&amp;gt;CommandType = CommandType::Text;&lt;br /&gt;
       cmd-&amp;gt;CommandText = &amp;quot;DELETE FROM Authors WHERE LastName = &amp;quot;Does&amp;quot;&amp;quot;;&lt;br /&gt;
       affected = cmd-&amp;gt;ExecuteNonQuery();&lt;br /&gt;
       if (affected &amp;lt;= 0)&lt;br /&gt;
           throw gcnew Exception(&amp;quot;Insert Failed&amp;quot;);&lt;br /&gt;
       Console::WriteLine(&amp;quot;Delete - {0} rows are affected&amp;quot;, affected);&lt;br /&gt;
       transaction-&amp;gt;Commit();&lt;br /&gt;
    }&lt;br /&gt;
    catch (Exception ^e)&lt;br /&gt;
    {&lt;br /&gt;
        transaction-&amp;gt;Rollback(&amp;quot;AuthorTransaction&amp;quot;);&lt;br /&gt;
        Console::WriteLine(&amp;quot;Transaction Not completed&amp;quot;);&lt;br /&gt;
        Console::WriteLine(&amp;quot;SQL error occurred: {0}&amp;quot;, e-&amp;gt;Message);&lt;br /&gt;
    }&lt;br /&gt;
    finally&lt;br /&gt;
    {&lt;br /&gt;
        connection-&amp;gt;Close();&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;
==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;
#include &amp;quot;stdafx.h&amp;quot;&lt;br /&gt;
using namespace System;&lt;br /&gt;
using namespace System::Data;&lt;br /&gt;
using namespace System::Data::OleDb;&lt;br /&gt;
ref struct MyEventHandler&lt;br /&gt;
{&lt;br /&gt;
    static void RowUpdated(Object^ sender, OleDbRowUpdatedEventArgs^ e)&lt;br /&gt;
    {&lt;br /&gt;
        if ( e-&amp;gt;Status == UpdateStatus::ErrorsOccurred )&lt;br /&gt;
            throw &amp;quot;Row update failed!&amp;quot;;&lt;br /&gt;
    }&lt;br /&gt;
};&lt;br /&gt;
void main()&lt;br /&gt;
{&lt;br /&gt;
    OleDbConnection^ myConnection = nullptr;&lt;br /&gt;
    OleDbTransaction^ myTransaction = nullptr;&lt;br /&gt;
    &lt;br /&gt;
    try&lt;br /&gt;
    {&lt;br /&gt;
        myConnection = gcnew OleDbConnection(&amp;quot;Provider=Microsoft.Jet.OLEDB.4.0;Data Source=Music.mdb&amp;quot;);&lt;br /&gt;
        myConnection-&amp;gt;Open();&lt;br /&gt;
        &lt;br /&gt;
        OleDbDataAdapter^ dataAdapter = gcnew OleDbDataAdapter(&amp;quot;SELECT * FROM Music&amp;quot;, myConnection);&lt;br /&gt;
        OleDbCommandBuilder^ commandBuilder = gcnew OleDbCommandBuilder(dataAdapter);&lt;br /&gt;
        dataAdapter-&amp;gt;UpdateCommand = commandBuilder-&amp;gt;GetUpdateCommand();&lt;br /&gt;
        &lt;br /&gt;
        dataAdapter-&amp;gt;RowUpdated += gcnew OleDbRowUpdatedEventHandler(MyEventHandler::RowUpdated);&lt;br /&gt;
        &lt;br /&gt;
        DataSet^ myDataSet = gcnew DataSet();&lt;br /&gt;
        dataAdapter-&amp;gt;MissingSchemaAction = MissingSchemaAction::AddWithKey;&lt;br /&gt;
        dataAdapter-&amp;gt;Fill(myDataSet);&lt;br /&gt;
        &lt;br /&gt;
        myTransaction = myConnection-&amp;gt;BeginTransaction();&lt;br /&gt;
        &lt;br /&gt;
        DataTable^ myTable = myDataSet-&amp;gt;Tables[0];&lt;br /&gt;
        &lt;br /&gt;
        DataRow^ row = myTable-&amp;gt;Rows-&amp;gt;Find(&amp;quot;Automatic&amp;quot;);&lt;br /&gt;
        if ( row != nullptr )&lt;br /&gt;
            row[&amp;quot;Title&amp;quot;] = &amp;quot;Automatic (Dance Mix)&amp;quot;;&lt;br /&gt;
        row = myTable-&amp;gt;Rows-&amp;gt;Find(&amp;quot;EnTrance&amp;quot;);        &lt;br /&gt;
        if ( row != nullptr )&lt;br /&gt;
            row[&amp;quot;GenreName&amp;quot;] = &amp;quot;Trance&amp;quot;;&lt;br /&gt;
        &lt;br /&gt;
        dataAdapter-&amp;gt;Update(myDataSet);&lt;br /&gt;
        myTransaction-&amp;gt;Commit();&lt;br /&gt;
    }&lt;br /&gt;
    catch(Exception^ e)&lt;br /&gt;
    {&lt;br /&gt;
        Console::WriteLine(e-&amp;gt;Message);&lt;br /&gt;
        if ( myTransaction != nullptr )&lt;br /&gt;
        {&lt;br /&gt;
            myTransaction-&amp;gt;Rollback();&lt;br /&gt;
            Console::WriteLine(&amp;quot;Transaction rolled back.&amp;quot;);&lt;br /&gt;
        }&lt;br /&gt;
    }&lt;br /&gt;
    finally&lt;br /&gt;
    {&lt;br /&gt;
        myConnection-&amp;gt;Close();&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>