mirror of
				https://github.com/django/django.git
				synced 2025-10-26 07:06:08 +00:00 
			
		
		
		
	The query used a construct of qs.annotate().values().aggregate() where
the first annotate used an F-object reference and the values() and
aggregate() calls referenced that F-object.
Also made sure the inner query's select clause is as simple as possible,
and made sure .values().distinct().aggreate() works correctly.
Backport of fb146193c4 from master
		
	
		
			
				
	
	
		
			76 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			76 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| """
 | |
| Tests for F() query expression syntax.
 | |
| """
 | |
| 
 | |
| from __future__ import unicode_literals
 | |
| 
 | |
| from django.db import models
 | |
| from django.utils.encoding import python_2_unicode_compatible
 | |
| 
 | |
| 
 | |
| @python_2_unicode_compatible
 | |
| class Employee(models.Model):
 | |
|     firstname = models.CharField(max_length=50)
 | |
|     lastname = models.CharField(max_length=50)
 | |
|     salary = models.IntegerField(blank=True, null=True)
 | |
| 
 | |
|     def __str__(self):
 | |
|         return '%s %s' % (self.firstname, self.lastname)
 | |
| 
 | |
| 
 | |
| @python_2_unicode_compatible
 | |
| class Company(models.Model):
 | |
|     name = models.CharField(max_length=100)
 | |
|     num_employees = models.PositiveIntegerField()
 | |
|     num_chairs = models.PositiveIntegerField()
 | |
|     ceo = models.ForeignKey(
 | |
|         Employee,
 | |
|         related_name='company_ceo_set')
 | |
|     point_of_contact = models.ForeignKey(
 | |
|         Employee,
 | |
|         related_name='company_point_of_contact_set',
 | |
|         null=True)
 | |
| 
 | |
|     def __str__(self):
 | |
|         return self.name
 | |
| 
 | |
| 
 | |
| @python_2_unicode_compatible
 | |
| class Number(models.Model):
 | |
|     integer = models.BigIntegerField(db_column='the_integer')
 | |
|     float = models.FloatField(null=True, db_column='the_float')
 | |
| 
 | |
|     def __str__(self):
 | |
|         return '%i, %.3f' % (self.integer, self.float)
 | |
| 
 | |
| 
 | |
| class Experiment(models.Model):
 | |
|     name = models.CharField(max_length=24)
 | |
|     assigned = models.DateField()
 | |
|     completed = models.DateField()
 | |
|     estimated_time = models.DurationField()
 | |
|     start = models.DateTimeField()
 | |
|     end = models.DateTimeField()
 | |
| 
 | |
|     class Meta:
 | |
|         ordering = ('name',)
 | |
| 
 | |
|     def duration(self):
 | |
|         return self.end - self.start
 | |
| 
 | |
| 
 | |
| @python_2_unicode_compatible
 | |
| class Time(models.Model):
 | |
|     time = models.TimeField(null=True)
 | |
| 
 | |
|     def __str__(self):
 | |
|         return "%s" % self.time
 | |
| 
 | |
| 
 | |
| @python_2_unicode_compatible
 | |
| class UUID(models.Model):
 | |
|     uuid = models.UUIDField(null=True)
 | |
| 
 | |
|     def __str__(self):
 | |
|         return "%s" % self.uuid
 |