mirror of
				https://github.com/django/django.git
				synced 2025-10-25 22:56:12 +00:00 
			
		
		
		
	Fixed #3790 -- Fixed a problem with sequence resetting during fixture loads when using Postgres. Thanks to Jon Ballard and scott@staplefish.com for the report, and to Zach Thompson for suggesting a solution.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@4937 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		| @@ -169,6 +169,31 @@ def get_sql_flush(style, tables, sequences): | ||||
|         return sql | ||||
|     else: | ||||
|         return [] | ||||
|  | ||||
| def get_sql_sequence_reset(style, model_list): | ||||
|     "Returns a list of the SQL statements to reset sequences for the given models." | ||||
|     from django.db import models | ||||
|     output = [] | ||||
|     for model in model_list: | ||||
|         for f in model._meta.fields: | ||||
|             if isinstance(f, models.AutoField): | ||||
|                 output.append("%s setval('%s', (%s max(%s) %s %s));" % \ | ||||
|                     (style.SQL_KEYWORD('SELECT'), | ||||
|                     style.SQL_FIELD('%s_%s_seq' % (model._meta.db_table, f.column)), | ||||
|                     style.SQL_KEYWORD('SELECT'), | ||||
|                     style.SQL_FIELD(quote_name(f.column)), | ||||
|                     style.SQL_KEYWORD('FROM'), | ||||
|                     style.SQL_TABLE(quote_name(model._meta.db_table)))) | ||||
|                 break # Only one AutoField is allowed per model, so don't bother continuing. | ||||
|         for f in model._meta.many_to_many: | ||||
|             output.append("%s setval('%s', (%s max(%s) %s %s));" % \ | ||||
|                 (style.SQL_KEYWORD('SELECT'), | ||||
|                 style.SQL_FIELD('%s_id_seq' % f.m2m_db_table()), | ||||
|                 style.SQL_KEYWORD('SELECT'), | ||||
|                 style.SQL_FIELD(quote_name('id')), | ||||
|                 style.SQL_KEYWORD('FROM'), | ||||
|                 style.SQL_TABLE(f.m2m_db_table()))) | ||||
|     return output | ||||
|          | ||||
| OPERATOR_MAPPING = { | ||||
|     'exact': '= %s', | ||||
|   | ||||
		Reference in New Issue
	
	Block a user