diff --git a/django/core/management/base.py b/django/core/management/base.py index 4016faaa7a..a07fc7d56f 100644 --- a/django/core/management/base.py +++ b/django/core/management/base.py @@ -218,13 +218,15 @@ class BaseCommand(object): output = self.handle(*args, **options) if output: if self.output_transaction: - # This needs to be imported here, because it relies on settings. - from django.db import connection + # This needs to be imported here, because it relies on + # settings. + from django.db import connections, DEFAULT_DB_ALIAS + connection = connections[options.get('database', DEFAULT_DB_ALIAS)] if connection.ops.start_transaction_sql(): print self.style.SQL_KEYWORD(connection.ops.start_transaction_sql()) print output if self.output_transaction: - print self.style.SQL_KEYWORD("COMMIT;") + print self.style.SQL_KEYWORD(connection.ops.end_transaction_sql()) except CommandError, e: sys.stderr.write(smart_str(self.style.ERROR('Error: %s\n' % e))) sys.exit(1) diff --git a/django/db/backends/__init__.py b/django/db/backends/__init__.py index 5918935899..fe2c7c451b 100644 --- a/django/db/backends/__init__.py +++ b/django/db/backends/__init__.py @@ -353,6 +353,11 @@ class BaseDatabaseOperations(object): """ return "BEGIN;" + def end_transaction_sql(self, success=True): + if not success: + return "ROLLBACK;" + return "COMMIT;" + def tablespace_sql(self, tablespace, inline=False): """ Returns the SQL that will be appended to tables or rows to define