1
0
mirror of synced 2025-01-06 00:57:10 +03:00
doctrine2/manual/new/docs/en/transactions/isolation-levels.txt
jepso 5329c3827c * Converted most of the docs to the new format.
* Fixed a few layout bugs in new documentation
* Fixed documentation table of contents indentation bug in IE6 (fixes #344)
* Fixed a parser bug in Sensei_Doc_Section
* Restructrured a bit some files of the documentation.
2007-06-13 21:30:32 +00:00

25 lines
1.3 KiB
Plaintext

A transaction isolation level sets the default transactional behaviour. As the name 'isolation level' suggests, the setting determines how isolated each transation is, or what kind of locks are associated with queries inside a transaction. The four availible levels are (in ascending order of strictness):
: {{READ UNCOMMITTED}} : Barely transactional, this setting allows for so-called 'dirty reads', where queries inside one transaction are affected by uncommitted changes in another transaction.
: {{READ COMMITTED}} : Committed updates are visible within another transaction. This means identical queries within a transaction can return differing results. This is the default in some DBMS's.
: {{REPEATABLE READ}} : Within a transaction, all reads are consistent. This is the default of Mysql INNODB engine.
: {{SERIALIZABLE}} : Updates are not permitted in other transactions if a transaction has run an ordinary {{SELECT}} query.
<code type="php">
$tx = $conn->transaction; // get the transaction module
// sets the isolation level to READ COMMITTED
$tx->setIsolation('READ COMMITTED');
// sets the isolation level to SERIALIZABLE
$tx->setIsolation('SERIALIZABLE');
// Some drivers (like Mysql) support the fetching of current transaction
// isolation level. It can be done as follows:
$level = $tx->getIsolation();
</code>