私の環境はpython2.7.3とdjango1.4.1です
MyISAM テーブルで MySQL を使用しています。
私のテストコード:
from django.core.management import setup_environ
from myproject import settings
setup_environ(settings)
from myproject.models import *
from django.db import transaction
@transaction.commit_manually
def test_trans():
r=tab1.objects.get(no="1")
r.value=100
r.save()
transaction.rollback()#I already rollback here, but data is still being updated to the database
def main():
try:
test_trans()
except:
pass
if __name__ == '__main__':
main()
データがまだデータベースに更新されているため、 transaction.rollback() が私のトランザクションをロールバックしていないようです。