[Zodb-checkins] CVS: ZODB3/ZODB - subtransactions.txt:1.1.2.1
    Fred L. Drake, Jr. 
    fred at zope.com
       
    Thu Jan 22 15:10:59 EST 2004
    
    
  
Update of /cvs-repository/ZODB3/ZODB
In directory cvs.zope.org:/tmp/cvs-serv3308
Added Files:
      Tag: zope3-zodb3-devel-branch
	subtransactions.txt 
Log Message:
Provide some explanation of the ways that ZODB 3 subtransactions work.
=== Added File ZODB3/ZODB/subtransactions.txt ===
=========================
Subtransactions in ZODB 3
=========================
ZODB 3 provides limited support for subtransactions. Subtransactions
are nested to *one* level. There are top-level transactions and
subtransactions.  When a transaction is committed, a flag is passed
indicating whether it is a subtransaction or a top-level transaction.
Consider the following exampler commit calls:
- commit()
  A regular top-level transaction is committed.
- commit(1)
  A subtransaction is committed. There is now one subtransaction of
  the current top-level transaction.
- commit(1)
  A subtransaction is committed. There are now two subtransactions of
  the current top-level transaction.
- abort(1)
  A subtransaction is aborted. There are still two subtransactions of
  the current top-level transaction; work done since the last
  commit(1) call is discarded.
- commit()
  We now commit a top-level transaction. The work done in the previous
  two subtransactions *plus* work done since the last abort(1) call
  is saved.
- commit(1)
  A subtransaction is committed. There is now one subtransaction of
  the current top-level transaction.
- commit(1)
  A subtransaction is committed. There are now two subtransactions of
  the current top-level transaction.
- abort()
  We now abort a top-level transaction. We discard the work done in
  the previous two subtransactions *plus* work done since the last
  commit(1) call.
    
    
More information about the Zodb-checkins
mailing list