Loading django/core/management/commands/sqlsequencereset.py +2 −0 Original line number Diff line number Diff line Loading @@ -3,6 +3,7 @@ from __future__ import unicode_literals from optparse import make_option from django.core.management.base import AppCommand from django.core.management.sql import check_for_migrations from django.db import connections, DEFAULT_DB_ALIAS Loading @@ -22,6 +23,7 @@ class Command(AppCommand): if app_config.models_module is None: return connection = connections[options.get('database')] check_for_migrations(app_config, connection) models = app_config.get_models(include_auto_created=True) statements = connection.ops.sequence_reset_sql(self.style, models) return '\n'.join(statements) django/core/management/sql.py +26 −2 Original line number Diff line number Diff line Loading @@ -12,9 +12,19 @@ from django.db import models, router from django.utils.deprecation import RemovedInDjango19Warning def check_for_migrations(app_config, connection): # Inner import, else tests imports it too early as it needs settings from django.db.migrations.loader import MigrationLoader loader = MigrationLoader(connection) if app_config.label in loader.migrated_apps: raise CommandError("App '%s' has migrations. Only the sqlmigrate and sqlflush commands can be used when an app has migrations." % app_config.label) def sql_create(app_config, style, connection): "Returns a list of the CREATE TABLE SQL statements for the given app." check_for_migrations(app_config, connection) if connection.settings_dict['ENGINE'] == 'django.db.backends.dummy': # This must be the "dummy" database backend, which means the user # hasn't set ENGINE for the database. Loading Loading @@ -58,9 +68,11 @@ def sql_create(app_config, style, connection): return final_output def sql_delete(app_config, style, connection): def sql_delete(app_config, style, connection, close_connection=True): "Returns a list of the DROP TABLE SQL statements for the given app." check_for_migrations(app_config, connection) # This should work even if a connection isn't available try: cursor = connection.cursor() Loading Loading @@ -97,7 +109,7 @@ def sql_delete(app_config, style, connection): finally: # Close database connection explicitly, in case this output is being piped # directly into a database client, to avoid locking issues. if cursor: if cursor and close_connection: cursor.close() connection.close() Loading @@ -122,6 +134,9 @@ def sql_flush(style, connection, only_django=False, reset_sequences=True, allow_ def sql_custom(app_config, style, connection): "Returns a list of the custom table modifying SQL statements for the given app." check_for_migrations(app_config, connection) output = [] app_models = router.get_migratable_models(app_config, connection.alias) Loading @@ -134,6 +149,9 @@ def sql_custom(app_config, style, connection): def sql_indexes(app_config, style, connection): "Returns a list of the CREATE INDEX SQL statements for all models in the given app." check_for_migrations(app_config, connection) output = [] for model in router.get_migratable_models(app_config, connection.alias, include_auto_created=True): output.extend(connection.creation.sql_indexes_for_model(model, style)) Loading @@ -142,6 +160,9 @@ def sql_indexes(app_config, style, connection): def sql_destroy_indexes(app_config, style, connection): "Returns a list of the DROP INDEX SQL statements for all models in the given app." check_for_migrations(app_config, connection) output = [] for model in router.get_migratable_models(app_config, connection.alias, include_auto_created=True): output.extend(connection.creation.sql_destroy_indexes_for_model(model, style)) Loading @@ -149,6 +170,9 @@ def sql_destroy_indexes(app_config, style, connection): def sql_all(app_config, style, connection): check_for_migrations(app_config, connection) "Returns a list of CREATE TABLE SQL, initial-data inserts, and CREATE INDEX SQL for the given module." return sql_create(app_config, style, connection) + sql_custom(app_config, style, connection) + sql_indexes(app_config, style, connection) Loading tests/commands_sql_migrations/__init__.py 0 → 100644 +0 −0 Empty file added. tests/commands_sql_migrations/migrations/0001_initial.py 0 → 100644 +33 −0 Original line number Diff line number Diff line # -*- coding: utf-8 -*- from __future__ import unicode_literals from django.db import models, migrations class Migration(migrations.Migration): dependencies = [ ] operations = [ migrations.CreateModel( name='Comment', fields=[ ('id', models.AutoField(verbose_name='ID', primary_key=True, serialize=False, auto_created=True)), ], options={ }, bases=(models.Model,), ), migrations.CreateModel( name='Book', fields=[ ('id', models.AutoField(verbose_name='ID', primary_key=True, serialize=False, auto_created=True)), ('title', models.CharField(db_index=True, max_length=100)), ('comments', models.ManyToManyField(to='commands_sql_migrations.Comment')), ], options={ }, bases=(models.Model,), ), ] tests/commands_sql_migrations/migrations/__init__.py 0 → 100644 +0 −0 Empty file added. Loading
django/core/management/commands/sqlsequencereset.py +2 −0 Original line number Diff line number Diff line Loading @@ -3,6 +3,7 @@ from __future__ import unicode_literals from optparse import make_option from django.core.management.base import AppCommand from django.core.management.sql import check_for_migrations from django.db import connections, DEFAULT_DB_ALIAS Loading @@ -22,6 +23,7 @@ class Command(AppCommand): if app_config.models_module is None: return connection = connections[options.get('database')] check_for_migrations(app_config, connection) models = app_config.get_models(include_auto_created=True) statements = connection.ops.sequence_reset_sql(self.style, models) return '\n'.join(statements)
django/core/management/sql.py +26 −2 Original line number Diff line number Diff line Loading @@ -12,9 +12,19 @@ from django.db import models, router from django.utils.deprecation import RemovedInDjango19Warning def check_for_migrations(app_config, connection): # Inner import, else tests imports it too early as it needs settings from django.db.migrations.loader import MigrationLoader loader = MigrationLoader(connection) if app_config.label in loader.migrated_apps: raise CommandError("App '%s' has migrations. Only the sqlmigrate and sqlflush commands can be used when an app has migrations." % app_config.label) def sql_create(app_config, style, connection): "Returns a list of the CREATE TABLE SQL statements for the given app." check_for_migrations(app_config, connection) if connection.settings_dict['ENGINE'] == 'django.db.backends.dummy': # This must be the "dummy" database backend, which means the user # hasn't set ENGINE for the database. Loading Loading @@ -58,9 +68,11 @@ def sql_create(app_config, style, connection): return final_output def sql_delete(app_config, style, connection): def sql_delete(app_config, style, connection, close_connection=True): "Returns a list of the DROP TABLE SQL statements for the given app." check_for_migrations(app_config, connection) # This should work even if a connection isn't available try: cursor = connection.cursor() Loading Loading @@ -97,7 +109,7 @@ def sql_delete(app_config, style, connection): finally: # Close database connection explicitly, in case this output is being piped # directly into a database client, to avoid locking issues. if cursor: if cursor and close_connection: cursor.close() connection.close() Loading @@ -122,6 +134,9 @@ def sql_flush(style, connection, only_django=False, reset_sequences=True, allow_ def sql_custom(app_config, style, connection): "Returns a list of the custom table modifying SQL statements for the given app." check_for_migrations(app_config, connection) output = [] app_models = router.get_migratable_models(app_config, connection.alias) Loading @@ -134,6 +149,9 @@ def sql_custom(app_config, style, connection): def sql_indexes(app_config, style, connection): "Returns a list of the CREATE INDEX SQL statements for all models in the given app." check_for_migrations(app_config, connection) output = [] for model in router.get_migratable_models(app_config, connection.alias, include_auto_created=True): output.extend(connection.creation.sql_indexes_for_model(model, style)) Loading @@ -142,6 +160,9 @@ def sql_indexes(app_config, style, connection): def sql_destroy_indexes(app_config, style, connection): "Returns a list of the DROP INDEX SQL statements for all models in the given app." check_for_migrations(app_config, connection) output = [] for model in router.get_migratable_models(app_config, connection.alias, include_auto_created=True): output.extend(connection.creation.sql_destroy_indexes_for_model(model, style)) Loading @@ -149,6 +170,9 @@ def sql_destroy_indexes(app_config, style, connection): def sql_all(app_config, style, connection): check_for_migrations(app_config, connection) "Returns a list of CREATE TABLE SQL, initial-data inserts, and CREATE INDEX SQL for the given module." return sql_create(app_config, style, connection) + sql_custom(app_config, style, connection) + sql_indexes(app_config, style, connection) Loading
tests/commands_sql_migrations/migrations/0001_initial.py 0 → 100644 +33 −0 Original line number Diff line number Diff line # -*- coding: utf-8 -*- from __future__ import unicode_literals from django.db import models, migrations class Migration(migrations.Migration): dependencies = [ ] operations = [ migrations.CreateModel( name='Comment', fields=[ ('id', models.AutoField(verbose_name='ID', primary_key=True, serialize=False, auto_created=True)), ], options={ }, bases=(models.Model,), ), migrations.CreateModel( name='Book', fields=[ ('id', models.AutoField(verbose_name='ID', primary_key=True, serialize=False, auto_created=True)), ('title', models.CharField(db_index=True, max_length=100)), ('comments', models.ManyToManyField(to='commands_sql_migrations.Comment')), ], options={ }, bases=(models.Model,), ), ]