红联Linux门户
Linux帮助

mysql的transaction level对django的影响

发布时间:2008-07-19 00:04:13来源:红联作者:isosdw
默认: transaction level对mysql是REPEATABLE READ, 这样一个mysql session内,每次读到的资料都是不变的, 不管其他事务对表做了什么更新. 这样性能比较高, 但却未必是得到准确的符合数据库最新情况的资料, 可能程序里会遭遇一些异常, 例如django的get_or_create()调用执行碰到奇怪: 明明是无法get, 自动转做create,但数据库就说记录冲突.

应该: 改用READ COMMITTED, 这是与oracle一致的.

在my.cnf里[mysqld]下写:

transaction-isolation=READ-COMMITTED

mysql> select @@global.tx_isolation;
+---------------+
| @@global.tx_isolation |
+---------------+
| READ-COMMITTED |
+---------------+
1 row in set (0.03 sec)
文章评论

共有 0 条评论