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:
parent
95e8688d7f
commit
ccbea84834
|
@ -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.
|
||||||
|
|
Loading…
Reference in New Issue