Это то, что у меня на вершине одного из моих скриптов загрузки данных.
import string
import sys
try:
import settings # Assumed to be in the same directory.
#settings.DISABLE_TRANSACTION_MANAGEMENT = True
except ImportError:
sys.stderr.write("Error: Can't find the file 'settings.py' in the directory containing %r. It appears you've customized things.\nYou'll have to run django-admin.py, passing it your settings module.\n(If the file settings.py does indeed exist, it's causing an ImportError somehow.)\n" % __file__)
sys.exit(1)
#Setup the django environment with the settings module.
import django
import django.core.management
django.core.management.setup_environ(settings)
from django.db import transaction
Все это должно быть выполнено, прежде чем вы сделаете что-то еще в вашем скрипте.
Еще один метод - использовать fixtures и manage.py. Хотя, если вы просто пытаетесь выполнить массовую загрузку данных для инициализации базы данных, это должно работать нормально.
Также в зависимости от того, что вы делаете, вы можете или не хотите делать все это в одной транзакции. Раскомментируйте строку транзакции выше и структурируйте свой код следующим образом.
transaction.enter_transaction_management()
try:
#Do some stuff
transaction.commit()
finally:
transaction.rollback()
pass
transaction.leave_transaction_management()