Với tập lệnh thử nghiệm nhỏ của tôi, không có bản ghi nào hiển thị trước cam kết nếu tôi đăng nhập từ một bảng điều khiển khác. Tuy nhiên, tôi có thể chọn các bản ghi vừa được chèn trong cùng một phiên. Vì vậy, tôi giả sử rằng trước khi cam kết, bạn có thể truy cập các hàng đã có trong bảng, nhưng bây giờ các hàng mới hoặc các thay đổi trước khi chúng được cam kết.
<?php
require_once('db.php');
q( 'drop table if exists t' );
q( 'create table t (id integer not null auto_increment primary key, v datetime) engine=innodb' );
q( 'set transaction isolation level read uncommitted' );
q( 'start transaction' );
q( 'insert into t (v) values (now()),(now()),(now())' );
echo q1( 'count(*)', 't', 'true'); // translates to "select count(*) from t where true";
// echoes "3" to the console
// wait for input
$handle = fopen ("php://stdin","r");
$line = fgets($handle);
// with a mysql client from a 2nd console at this point no new records show in table t
q( 'commit' );
// after this point all new records show up in table t from a 2nd session.