django1/django/core/management/commands/sqlsequencereset.py

26 lines
982 B
Python
Raw Normal View History

from django.core.management.base import AppCommand
from django.db import DEFAULT_DB_ALIAS, connections
2013-11-03 04:12:09 +08:00
class Command(AppCommand):
help = 'Prints the SQL statements for resetting sequences for the given app name(s).'
output_transaction = True
def add_arguments(self, parser):
super().add_arguments(parser)
2016-03-29 06:33:29 +08:00
parser.add_argument(
'--database', default=DEFAULT_DB_ALIAS,
help='Nominates a database to print the SQL for. Defaults to the "default" database.',
)
def handle_app_config(self, app_config, **options):
if app_config.models_module is None:
return
connection = connections[options['database']]
2013-12-30 03:26:13 +08:00
models = app_config.get_models(include_auto_created=True)
statements = connection.ops.sequence_reset_sql(self.style, models)
if not statements and options['verbosity'] >= 1:
self.stderr.write('No sequences found.')
return '\n'.join(statements)