<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
		<id>http://www.vbex.ru/index.php?action=history&amp;feed=atom&amp;title=VBA%2FExcel%2FAccess%2FWord%2FAccess%2FTransaction</id>
		<title>VBA/Excel/Access/Word/Access/Transaction - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://www.vbex.ru/index.php?action=history&amp;feed=atom&amp;title=VBA%2FExcel%2FAccess%2FWord%2FAccess%2FTransaction"/>
		<link rel="alternate" type="text/html" href="http://www.vbex.ru/index.php?title=VBA/Excel/Access/Word/Access/Transaction&amp;action=history"/>
		<updated>2026-04-07T01:27:30Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://www.vbex.ru/index.php?title=VBA/Excel/Access/Word/Access/Transaction&amp;diff=1352&amp;oldid=prev</id>
		<title> в 16:33, 26 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://www.vbex.ru/index.php?title=VBA/Excel/Access/Word/Access/Transaction&amp;diff=1352&amp;oldid=prev"/>
				<updated>2010-05-26T16:33:00Z</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;Версия 16:33, 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.vbex.ru/index.php?title=VBA/Excel/Access/Word/Access/Transaction&amp;diff=1353&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://www.vbex.ru/index.php?title=VBA/Excel/Access/Word/Access/Transaction&amp;diff=1353&amp;oldid=prev"/>
				<updated>2010-05-26T12:46:53Z</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;==Rollback a transaction==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;vb&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
Sub exaCreateAction2()&lt;br /&gt;
    Dim ws As Workspace&lt;br /&gt;
    Dim db As Database&lt;br /&gt;
    Dim qdf As QueryDef&lt;br /&gt;
    Dim strSQL As String&lt;br /&gt;
    &lt;br /&gt;
    Set ws = DBEngine(0)&lt;br /&gt;
    Set db = CurrentDb&lt;br /&gt;
    &lt;br /&gt;
    strSQL = &amp;quot;UPDATE BOOKS SET Price = Price*1.1 WHERE Price &amp;gt; 20&amp;quot;&lt;br /&gt;
    &lt;br /&gt;
    Set qdf = db.CreateQueryDef(&amp;quot;PriceInc&amp;quot;, strSQL)&lt;br /&gt;
    ws.BeginTrans&lt;br /&gt;
    qdf.Execute&lt;br /&gt;
    If qdf.RecordsAffected &amp;gt; 15 Then&lt;br /&gt;
        Debug.Print qdf.RecordsAffected &lt;br /&gt;
        ws.Rollback&lt;br /&gt;
    Else&lt;br /&gt;
        Debug.Print qdf.RecordsAffected&lt;br /&gt;
        ws.rumitTrans&lt;br /&gt;
    End If&lt;br /&gt;
End Sub&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Transaction Processing in Access sing BeginTrans, Logging, CommitTrans, and RollbackTrans==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;vb&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
Sub IncreaseQuantityTrans()&lt;br /&gt;
    On Error GoTo IncreaseQuantityTrans_Err&lt;br /&gt;
    Dim cnn As ADODB.Connection&lt;br /&gt;
    Dim rst As ADODB.Recordset&lt;br /&gt;
    Dim boolInTrans As Boolean&lt;br /&gt;
    boolInTrans = False&lt;br /&gt;
   Set rst = New ADODB.Recordset&lt;br /&gt;
    Set cnn = CurrentProject.Connection&lt;br /&gt;
    rst.ActiveConnection = cnn&lt;br /&gt;
    rst.CursorType = adOpenKeyset&lt;br /&gt;
    rst.LockType = adLockOptimistic&lt;br /&gt;
    rst.Open &amp;quot;Select ProductID, UnitPrice From Products&amp;quot;&lt;br /&gt;
    cnn.BeginTrans&lt;br /&gt;
        boolInTrans = True&lt;br /&gt;
        Do Until rst.EOF&lt;br /&gt;
            rst!UnitPrice = rst!UnitPrice + 1&lt;br /&gt;
            rst.Update&lt;br /&gt;
            rst.MoveNext&lt;br /&gt;
        Loop&lt;br /&gt;
    cnn.rumitTrans&lt;br /&gt;
    boolInTrans = False&lt;br /&gt;
IncreaseQuantityTrans_Exit:&lt;br /&gt;
    Set cnn = Nothing&lt;br /&gt;
    Set rst = Nothing&lt;br /&gt;
    Exit Sub&lt;br /&gt;
IncreaseQuantityTrans_Err:&lt;br /&gt;
    msgBox &amp;quot;Error # &amp;quot; &amp;amp; Err.number &amp;amp; &amp;quot;: &amp;quot; &amp;amp; Err.Description&lt;br /&gt;
    If boolInTrans Then&lt;br /&gt;
        cnn.RollbackTrans&lt;br /&gt;
    End If&lt;br /&gt;
    Resume IncreaseQuantityTrans_Exit&lt;br /&gt;
End Sub&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Use transaction==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;vb&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
Sub TestTransaction()&lt;br /&gt;
    Dim cnConnection As New ADODB.Connection&lt;br /&gt;
    Dim cmdCommand As New ADODB.rumand&lt;br /&gt;
    Set cnConnection = CurrentProject.Connection&lt;br /&gt;
    cmdCommand.ActiveConnection = cnConnection&lt;br /&gt;
    &lt;br /&gt;
    On Error GoTo HandleError&lt;br /&gt;
    cnConnection.BeginTrans&lt;br /&gt;
    cmdCommand.rumandText = &amp;quot;UPDATE tblContacts SET FirstName = &amp;quot;Test&amp;quot; WHERE ContactId = 1&amp;quot;&lt;br /&gt;
    cmdCommand.Execute&lt;br /&gt;
    cmdCommand.rumandText = &amp;quot;UPDATE tblContacts SET ContactId = &amp;quot;A&amp;quot; WHERE ContactId = 1&amp;quot;&lt;br /&gt;
    cmdCommand.Execute&lt;br /&gt;
    cnConnection.rumitTrans&lt;br /&gt;
    Exit Sub&lt;br /&gt;
    HandleError:&lt;br /&gt;
        cnConnection.RollbackTrans&lt;br /&gt;
        MsgBox &amp;quot;An error occurred: &amp;quot; &amp;amp; Err.Description&lt;br /&gt;
End Sub&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Using a Database Transaction to Insert Records==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;vb&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
Sub Create_Transaction()&lt;br /&gt;
    Dim conn As ADODB.Connection&lt;br /&gt;
    On Error GoTo ErrorHandler&lt;br /&gt;
    Set conn = New ADODB.Connection&lt;br /&gt;
    With conn&lt;br /&gt;
        .Provider = &amp;quot;Microsoft.Jet.OLEDB.4.0&amp;quot;&lt;br /&gt;
        .ConnectionString = &amp;quot;Data Source = &amp;quot; &amp;amp; CurrentProject.Path &amp;amp; &amp;quot;\mydb.mdb&amp;quot;&lt;br /&gt;
        .Open&lt;br /&gt;
        .BeginTrans&lt;br /&gt;
           .Execute &amp;quot;INSERT INTO Customers Values(&amp;quot;A&amp;quot;,&amp;quot;P&amp;quot;,&amp;quot;M&amp;quot;, &amp;quot;Manager&amp;quot;, &amp;quot;M 10&amp;quot;,&amp;quot;W&amp;quot;, Null, &amp;quot;02-111&amp;quot;, &amp;quot;Vancouver&amp;quot;, &amp;quot;0000000000000&amp;quot;, Null)&amp;quot;&lt;br /&gt;
           .Execute &amp;quot;INSERT INTO Orders (CustomerId, EmployeeId, OrderDate, RequiredDate) Values (&amp;quot;G&amp;quot;, 1, Date(), Date()+5)&amp;quot;&lt;br /&gt;
         .rumitTrans&lt;br /&gt;
         .Close&lt;br /&gt;
         Debug.Print &amp;quot;Both inserts completed.&amp;quot;&lt;br /&gt;
     End With&lt;br /&gt;
ExitHere:&lt;br /&gt;
     Set conn = Nothing&lt;br /&gt;
     Exit Sub&lt;br /&gt;
ErrorHandler:&lt;br /&gt;
     If Err.Number = -2147467259 Then&lt;br /&gt;
        MsgBox Err.Description&lt;br /&gt;
        Resume ExitHere&lt;br /&gt;
     Else&lt;br /&gt;
         MsgBox Err.Description&lt;br /&gt;
         With conn&lt;br /&gt;
             .RollbackTrans&lt;br /&gt;
             .Close&lt;br /&gt;
         End With&lt;br /&gt;
         Resume ExitHere&lt;br /&gt;
     End If&lt;br /&gt;
End Sub&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>