mirror of
				https://github.com/django/django.git
				synced 2025-10-25 22:56:12 +00:00 
			
		
		
		
	git-svn-id: http://code.djangoproject.com/svn/django/branches/magic-removal@2179 bcc190cf-cafb-0310-a4f2-bffc1f526a37
		
			
				
	
	
		
			157 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			157 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| """
 | |
| 7. The lookup API
 | |
| 
 | |
| This demonstrates features of the database API.
 | |
| """
 | |
| 
 | |
| from django.db import models
 | |
| 
 | |
| class Article(models.Model):
 | |
|     headline = models.CharField(maxlength=100)
 | |
|     pub_date = models.DateTimeField()
 | |
|     class Meta:
 | |
|         ordering = ('-pub_date', 'headline')
 | |
| 
 | |
|     def __repr__(self):
 | |
|         return self.headline
 | |
| 
 | |
| API_TESTS = """
 | |
| # Create a couple of Articles.
 | |
| >>> from datetime import datetime
 | |
| >>> a1 = Article(headline='Article 1', pub_date=datetime(2005, 7, 26))
 | |
| >>> a1.save()
 | |
| >>> a2 = Article(headline='Article 2', pub_date=datetime(2005, 7, 27))
 | |
| >>> a2.save()
 | |
| >>> a3 = Article(headline='Article 3', pub_date=datetime(2005, 7, 27))
 | |
| >>> a3.save()
 | |
| >>> a4 = Article(headline='Article 4', pub_date=datetime(2005, 7, 28))
 | |
| >>> a4.save()
 | |
| >>> a5 = Article(headline='Article 5', pub_date=datetime(2005, 8, 1, 9, 0))
 | |
| >>> a5.save()
 | |
| >>> a6 = Article(headline='Article 6', pub_date=datetime(2005, 8, 1, 8, 0))
 | |
| >>> a6.save()
 | |
| >>> a7 = Article(headline='Article 7', pub_date=datetime(2005, 7, 27))
 | |
| >>> a7.save()
 | |
| 
 | |
| # iterator() is a generator.
 | |
| >>> for a in Article.objects.iterator():
 | |
| ...     print a.headline
 | |
| Article 5
 | |
| Article 6
 | |
| Article 4
 | |
| Article 2
 | |
| Article 3
 | |
| Article 7
 | |
| Article 1
 | |
| 
 | |
| # iterator() can be used on any QuerySet.
 | |
| >>> for a in Article.objects.filter(headline__endswith='4').iterator():
 | |
| ...     print a.headline
 | |
| Article 4
 | |
| 
 | |
| # count() returns the number of objects matching search criteria.
 | |
| >>> Article.objects.count()
 | |
| 7L
 | |
| >>> Article.objects.filter(pub_date__exact=datetime(2005, 7, 27)).count()
 | |
| 3L
 | |
| >>> Article.objects.filter(headline__startswith='Blah blah').count()
 | |
| 0L
 | |
| 
 | |
| # in_bulk() takes a list of IDs and returns a dictionary mapping IDs
 | |
| # to objects.
 | |
| >>> Article.objects.in_bulk([1, 2])
 | |
| {1: Article 1, 2: Article 2}
 | |
| >>> Article.objects.in_bulk([3])
 | |
| {3: Article 3}
 | |
| >>> Article.objects.in_bulk([1000])
 | |
| {}
 | |
| >>> Article.objects.in_bulk([])
 | |
| Traceback (most recent call last):
 | |
|     ...
 | |
| AssertionError: in_bulk() cannot be passed an empty ID list.
 | |
| >>> Article.objects.in_bulk('foo')
 | |
| Traceback (most recent call last):
 | |
|     ...
 | |
| AssertionError: in_bulk() must be provided with a list of IDs.
 | |
| >>> Article.objects.in_bulk()
 | |
| Traceback (most recent call last):
 | |
|     ...
 | |
| TypeError: in_bulk() takes exactly 2 arguments (1 given)
 | |
| >>> Article.objects.in_bulk(headline__startswith='Blah')
 | |
| Traceback (most recent call last):
 | |
|     ...
 | |
| TypeError: in_bulk() got an unexpected keyword argument 'headline__startswith'
 | |
| 
 | |
| # get_values() is just like get_list(), except it returns a list of
 | |
| # dictionaries instead of object instances -- and you can specify which fields
 | |
| # you want to retrieve.
 | |
| >>> Article.objects.get_values(fields=['headline'])
 | |
| [{'headline': 'Article 5'}, {'headline': 'Article 6'}, {'headline': 'Article 4'}, {'headline': 'Article 2'}, {'headline': 'Article 3'}, {'headline': 'Article 7'}, {'headline': 'Article 1'}]
 | |
| >>> Article.objects.get_values(pub_date__exact=datetime(2005, 7, 27), fields=['id'])
 | |
| [{'id': 2}, {'id': 3}, {'id': 7}]
 | |
| >>> Article.objects.get_values(fields=['id', 'headline']) == [{'id': 5, 'headline': 'Article 5'}, {'id': 6, 'headline': 'Article 6'}, {'id': 4, 'headline': 'Article 4'}, {'id': 2, 'headline': 'Article 2'}, {'id': 3, 'headline': 'Article 3'}, {'id': 7, 'headline': 'Article 7'}, {'id': 1, 'headline': 'Article 1'}]
 | |
| True
 | |
| 
 | |
| # get_values_iterator() is just like get_values(), but it's a generator.
 | |
| >>> for d in Article.objects.get_values_iterator(fields=['id', 'headline']):
 | |
| ...     i = d.items()
 | |
| ...     i.sort()
 | |
| ...     i
 | |
| [('headline', 'Article 5'), ('id', 5)]
 | |
| [('headline', 'Article 6'), ('id', 6)]
 | |
| [('headline', 'Article 4'), ('id', 4)]
 | |
| [('headline', 'Article 2'), ('id', 2)]
 | |
| [('headline', 'Article 3'), ('id', 3)]
 | |
| [('headline', 'Article 7'), ('id', 7)]
 | |
| [('headline', 'Article 1'), ('id', 1)]
 | |
| 
 | |
| # Every DateField and DateTimeField creates get_next_by_FOO() and
 | |
| # get_previous_by_FOO() methods.
 | |
| # In the case of identical date values, these methods will use the ID as a
 | |
| # fallback check. This guarantees that no records are skipped or duplicated.
 | |
| >>> a1.get_next_by_pub_date()
 | |
| Article 2
 | |
| >>> a2.get_next_by_pub_date()
 | |
| Article 3
 | |
| >>> a3.get_next_by_pub_date()
 | |
| Article 7
 | |
| >>> a4.get_next_by_pub_date()
 | |
| Article 6
 | |
| >>> a5.get_next_by_pub_date()
 | |
| Traceback (most recent call last):
 | |
|     ...
 | |
| DoesNotExist: Article does not exist for ...
 | |
| >>> a6.get_next_by_pub_date()
 | |
| Article 5
 | |
| >>> a7.get_next_by_pub_date()
 | |
| Article 4
 | |
| 
 | |
| >>> a7.get_previous_by_pub_date()
 | |
| Article 3
 | |
| >>> a6.get_previous_by_pub_date()
 | |
| Article 4
 | |
| >>> a5.get_previous_by_pub_date()
 | |
| Article 6
 | |
| >>> a4.get_previous_by_pub_date()
 | |
| Article 7
 | |
| >>> a3.get_previous_by_pub_date()
 | |
| Article 2
 | |
| >>> a2.get_previous_by_pub_date()
 | |
| Article 1
 | |
| 
 | |
| # Underscores and percent signs have special meaning in the underlying
 | |
| # database library, but Django handles the quoting of them automatically.
 | |
| >>> a8 = Article(headline='Article_ with underscore', pub_date=datetime(2005, 11, 20))
 | |
| >>> a8.save()
 | |
| >>> list(Article.objects.filter(headline__startswith='Article'))
 | |
| [Article_ with underscore, Article 5, Article 6, Article 4, Article 2, Article 3, Article 7, Article 1]
 | |
| >>> list(Article.objects.filter(headline__startswith='Article_'))
 | |
| [Article_ with underscore]
 | |
| >>> a9 = Article(headline='Article% with percent sign', pub_date=datetime(2005, 11, 21))
 | |
| >>> a9.save()
 | |
| >>> list(Article.objects.filter(headline__startswith='Article'))
 | |
| [Article% with percent sign, Article_ with underscore, Article 5, Article 6, Article 4, Article 2, Article 3, Article 7, Article 1]
 | |
| >>> list(Article.objects.filter(headline__startswith='Article%'))
 | |
| [Article% with percent sign]
 | |
| """
 |