mirror of
				https://github.com/django/django.git
				synced 2025-10-26 07:06:08 +00:00 
			
		
		
		
	Fixed #404 -- Fixed random ordering in MySQL by abstracting random function into db backend modules. Thanks, mattycakes@gmail.com
git-svn-id: http://code.djangoproject.com/svn/django/trunk@615 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		| @@ -38,6 +38,7 @@ get_last_insert_id = dbmod.get_last_insert_id | |||||||
| get_date_extract_sql = dbmod.get_date_extract_sql | get_date_extract_sql = dbmod.get_date_extract_sql | ||||||
| get_date_trunc_sql = dbmod.get_date_trunc_sql | get_date_trunc_sql = dbmod.get_date_trunc_sql | ||||||
| get_limit_offset_sql = dbmod.get_limit_offset_sql | get_limit_offset_sql = dbmod.get_limit_offset_sql | ||||||
|  | get_random_function_sql = dbmod.get_random_function_sql | ||||||
| get_table_list = dbmod.get_table_list | get_table_list = dbmod.get_table_list | ||||||
| get_relations = dbmod.get_relations | get_relations = dbmod.get_relations | ||||||
| OPERATOR_MAPPING = dbmod.OPERATOR_MAPPING | OPERATOR_MAPPING = dbmod.OPERATOR_MAPPING | ||||||
|   | |||||||
| @@ -77,6 +77,9 @@ def get_limit_offset_sql(limit, offset=None): | |||||||
|         sql += "%s," % offset |         sql += "%s," % offset | ||||||
|     return sql + str(limit) |     return sql + str(limit) | ||||||
|  |  | ||||||
|  | def get_random_function_sql(): | ||||||
|  |     return "RAND()" | ||||||
|  |  | ||||||
| def get_table_list(cursor): | def get_table_list(cursor): | ||||||
|     "Returns a list of table names in the current database." |     "Returns a list of table names in the current database." | ||||||
|     cursor.execute("SHOW TABLES") |     cursor.execute("SHOW TABLES") | ||||||
|   | |||||||
| @@ -77,6 +77,9 @@ def get_limit_offset_sql(limit, offset=None): | |||||||
|         sql += " OFFSET %s" % offset |         sql += " OFFSET %s" % offset | ||||||
|     return sql |     return sql | ||||||
|  |  | ||||||
|  | def get_random_function_sql(): | ||||||
|  |     return "RANDOM()" | ||||||
|  |  | ||||||
| def get_table_list(cursor): | def get_table_list(cursor): | ||||||
|     "Returns a list of table names in the current database." |     "Returns a list of table names in the current database." | ||||||
|     cursor.execute(""" |     cursor.execute(""" | ||||||
|   | |||||||
| @@ -103,6 +103,9 @@ def get_limit_offset_sql(limit, offset=None): | |||||||
|         sql += " OFFSET %s" % offset |         sql += " OFFSET %s" % offset | ||||||
|     return sql |     return sql | ||||||
|  |  | ||||||
|  | def get_random_function_sql(): | ||||||
|  |     return "RANDOM()" | ||||||
|  |  | ||||||
| def _sqlite_date_trunc(lookup_type, dt): | def _sqlite_date_trunc(lookup_type, dt): | ||||||
|     try: |     try: | ||||||
|         dt = typecasts.typecast_timestamp(dt) |         dt = typecasts.typecast_timestamp(dt) | ||||||
|   | |||||||
| @@ -62,7 +62,7 @@ def orderlist2sql(order_list, opts, prefix=''): | |||||||
|         if f.startswith('-'): |         if f.startswith('-'): | ||||||
|             output.append('%s%s DESC' % (prefix, orderfield2column(f[1:], opts))) |             output.append('%s%s DESC' % (prefix, orderfield2column(f[1:], opts))) | ||||||
|         elif f == '?': |         elif f == '?': | ||||||
|             output.append('RANDOM()') |             output.append(db.get_random_function_sql()) | ||||||
|         else: |         else: | ||||||
|             output.append('%s%s ASC' % (prefix, orderfield2column(f, opts))) |             output.append('%s%s ASC' % (prefix, orderfield2column(f, opts))) | ||||||
|     return ', '.join(output) |     return ', '.join(output) | ||||||
| @@ -1319,7 +1319,7 @@ def function_get_sql_clause(opts, **kwargs): | |||||||
|     order_by = [] |     order_by = [] | ||||||
|     for f in handle_legacy_orderlist(kwargs.get('order_by', opts.ordering)): |     for f in handle_legacy_orderlist(kwargs.get('order_by', opts.ordering)): | ||||||
|         if f == '?': # Special case. |         if f == '?': # Special case. | ||||||
|             order_by.append('RANDOM()') |             order_by.append(db.get_random_function_sql()) | ||||||
|         else: |         else: | ||||||
|             # Use the database table as a column prefix if it wasn't given, |             # Use the database table as a column prefix if it wasn't given, | ||||||
|             # and if the requested column isn't a custom SELECT. |             # and if the requested column isn't a custom SELECT. | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user