OSDN Git Service

Add text:
authorBruce Momjian <bruce@momjian.us>
Fri, 2 Sep 2005 15:22:44 +0000 (15:22 +0000)
committerBruce Momjian <bruce@momjian.us>
Fri, 2 Sep 2005 15:22:44 +0000 (15:22 +0000)
commitfad7e8edac3348ea14aca379e7b3b2d713746cd3
tree126bd29aa6d734243a41ac28adb3faa3d9e28f71
parent6c0398a73f0a8173996fb0bd638ca6ab7c82e5b6
Add text:

* Merge xmin/xmax/cmin/cmax back into three header fields

  Before subtransactions, there used to be only three fields needed to
  store these four values. This was possible because only the current
  transaction looks at the cmin/cmax values. If the current transaction
  created and expired the row the fields stored where xmin (same as
  xmax), cmin, cmax, and if the transaction was expiring a row from a
  another transaction, the fields stored were xmin (cmin was not
  needed), xmax, and cmax. Such a system worked because a transaction
  could only see committed rows from another transaction. However,
  subtransactions can see rows from outer transactions, and once the
  subtransaction completes, the outer transaction continues, requiring
  the storage of all four fields. With subtransactions, an outer
  transaction can create a row, a subtransaction expire it, and when the
  subtransaction completes, the outer transaction still has to have
  proper visibility of the row, for example, for cursors.

  One possible solution is to create a phantom cid which represents a
  cmin/cmax pair and is stored in local memory.
doc/TODO
doc/src/FAQ/TODO.html