Skip to content

Commit

Permalink
Merge pull request #6 from django-nonrel/feature/refactor-ordering
Browse files Browse the repository at this point in the history
Refactored _get_ordering

Also fixes some issues with ordering and custom `db_column`s.

Thanks to everybody involved!
  • Loading branch information
jonashaag committed Dec 28, 2011
2 parents 12a4819 + 3a3fcf0 commit bd292d6
Show file tree
Hide file tree
Showing 2 changed files with 27 additions and 27 deletions.
37 changes: 10 additions & 27 deletions djangotoolbox/db/basecompiler.py
Original file line number Diff line number Diff line change
Expand Up @@ -188,16 +188,10 @@ def _matches_filters(self, entity, filters):
return result

def _order_in_memory(self, lhs, rhs):
for order in self.compiler._get_ordering():
if LOOKUP_SEP in order:
raise DatabaseError("JOINs in ordering not supported (%s)" % order)
if order == '?':
result = random.choice([1, 0, -1])
else:
column = order.lstrip('-')
result = cmp(lhs.get(column), rhs.get(column))
if order.startswith('-'):
result *= -1
for column, descending in self.compiler._get_ordering():
result = cmp(lhs.get(column), rhs.get(column))
if descending:
result *= -1
if result != 0:
return result
return 0
Expand Down Expand Up @@ -329,33 +323,22 @@ def get_fields(self):
return fields

def _get_ordering(self):
opts = self.query.get_meta()
if not self.query.default_ordering:
ordering = self.query.order_by
else:
ordering = self.query.order_by or self.query.get_meta().ordering
result = []
ordering = self.query.order_by or opts.ordering
for order in ordering:
if LOOKUP_SEP in order:
raise DatabaseError("Ordering can't span tables on non-relational backends (%s)" % order)
if order == '?':
raise DatabaseError("Randomized ordering isn't supported by the backend")

order = order.lstrip('+')

descending = order.startswith('-')
name = order.lstrip('-')
if name == 'pk':
name = self.query.get_meta().pk.name
order = '-' + name if descending else name

if self.query.standard_ordering:
result.append(order)
else:
if descending:
result.append(name)
else:
result.append('-' + name)
return result
field = order.lstrip('-')
if field == 'pk':
field = opts.pk.name
yield (opts.get_field(field).column, descending)

class NonrelInsertCompiler(object):
def execute_sql(self, return_id=False):
Expand Down
17 changes: 17 additions & 0 deletions djangotoolbox/tests.py
Original file line number Diff line number Diff line change
Expand Up @@ -394,3 +394,20 @@ def test_select_related(self):
source = Source.objects.all().select_related('target')[0]
self.assertEqual(source.target.pk, target.pk)
self.assertEqual(source.target.index, target.index)

class OrderByTest(TestCase):
def test_foreign_keys(self):
target1 = Target.objects.create(index=1)
target2 = Target.objects.create(index=2)
source1 = Source.objects.create(target=target1, index=3)
source2 = Source.objects.create(target=target2, index=4)
self.assertEqual(list(Source.objects.all().order_by('target')), [source1, source2])
self.assertEqual(list(Source.objects.all().order_by('-target')), [source2, source1])

def test_db_column(self):
class DBColumn(models.Model):
a = models.IntegerField(db_column='b')
model1 = DBColumn.objects.create(a=1)
model2 = DBColumn.objects.create(a=2)
self.assertEqual(list(DBColumn.objects.all().order_by('a')), [model1, model2])
self.assertEqual(list(DBColumn.objects.all().order_by('-a')), [model2, model1])

0 comments on commit bd292d6

Please sign in to comment.