Fixed small typo in overview

git-svn-id: http://code.djangoproject.com/svn/django/trunk@90 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
Adrian Holovaty 2005-07-16 02:40:24 +00:00
parent 8d0610d054
commit 07c8a965b6
1 changed files with 24 additions and 24 deletions

View File

@ -24,10 +24,10 @@ solving two years' worth of database-schema problems. Here's a quick example::
fields = ( fields = (
meta.CharField('full_name', "reporter's full name", maxlength=70), meta.CharField('full_name', "reporter's full name", maxlength=70),
) )
def __repr__(self): def __repr__(self):
return self.full_name return self.full_name
class Article(meta.Model): class Article(meta.Model):
fields = ( fields = (
meta.DateTimeField('pub_date', 'publication date'), meta.DateTimeField('pub_date', 'publication date'),
@ -35,7 +35,7 @@ solving two years' worth of database-schema problems. Here's a quick example::
meta.TextField('article', 'article'), meta.TextField('article', 'article'),
meta.ForeignKey(Reporter), meta.ForeignKey(Reporter),
) )
def __repr__(self): def __repr__(self):
return self.headline return self.headline
@ -58,29 +58,29 @@ is created on the fly: No code generation necessary::
# Modules are dynamically created within django.models. # Modules are dynamically created within django.models.
# Their names are plural versions of the model class names. # Their names are plural versions of the model class names.
>>> from django.models.news import reporters, articles >>> from django.models.news import reporters, articles
# No reporters are in the system yet. # No reporters are in the system yet.
>>> reporters.get_list() >>> reporters.get_list()
[] []
# Create a new Reporter. # Create a new Reporter.
>>> r = reporters.Reporter(id=None, full_name='John Smith') >>> r = reporters.Reporter(id=None, full_name='John Smith')
# Save the object into the database. You have to call save() explicitly. # Save the object into the database. You have to call save() explicitly.
>>> r.save() >>> r.save()
# Now it has an ID. # Now it has an ID.
>>> r.id >>> r.id
1 1
# Now the new reporter is in the database. # Now the new reporter is in the database.
>>> reporters.get_list() >>> reporters.get_list()
[John Smith] [John Smith]
# Fields are represented as attributes on the Python object. # Fields are represented as attributes on the Python object.
>>> r.full_name >>> r.full_name
'John Smith' 'John Smith'
# Django provides a rich database lookup API that's entirely driven by keyword arguments. # Django provides a rich database lookup API that's entirely driven by keyword arguments.
>>> reporters.get_object(id__exact=1) >>> reporters.get_object(id__exact=1)
John Smith John Smith
@ -91,35 +91,35 @@ is created on the fly: No code generation necessary::
>>> reporters.get_object(id__exact=2) >>> reporters.get_object(id__exact=2)
Traceback (most recent call last): Traceback (most recent call last):
... ...
django.models.polls.ReporterDoesNotExist: Reporter does not exist for {'id__exact': 2} django.models.news.ReporterDoesNotExist: Reporter does not exist for {'id__exact': 2}
# Create an article. # Create an article.
>>> from datetime import datetime >>> from datetime import datetime
>>> a = articles.Article(id=None, pub_date=datetime.now(), headline='Django is cool', article='Yeah.', reporter_id=1) >>> a = articles.Article(id=None, pub_date=datetime.now(), headline='Django is cool', article='Yeah.', reporter_id=1)
>>> a.save() >>> a.save()
# Now the article is in the database. # Now the article is in the database.
>>> articles.get_list() >>> articles.get_list()
[Django is cool] [Django is cool]
# Article objects get API access to related Reporter objects. # Article objects get API access to related Reporter objects.
>>> r = a.get_reporter() >>> r = a.get_reporter()
>>> r.full_name >>> r.full_name
'John Smith' 'John Smith'
# And vice versa: Reporter objects get API access to Article objects. # And vice versa: Reporter objects get API access to Article objects.
>>> r.get_article_list() >>> r.get_article_list()
[Django is cool] [Django is cool]
# The API follows relationships as far as you need. # The API follows relationships as far as you need.
# Find all articles by a reporter whose name starts with "John". # Find all articles by a reporter whose name starts with "John".
>>> articles.get_list(reporter__full_name__startswith="John") >>> articles.get_list(reporter__full_name__startswith="John")
[Django is cool] [Django is cool]
# Change an object by altering its attributes and calling save(). # Change an object by altering its attributes and calling save().
>>> r.full_name = 'Billy Goat' >>> r.full_name = 'Billy Goat'
>>> r.save() >>> r.save()
# Delete an object with delete(). # Delete an object with delete().
>>> r.delete() >>> r.delete()
@ -167,7 +167,7 @@ To design URLs for an app, you create a Python module. For the above
Reporter/Article example, here's what that might look like:: Reporter/Article example, here's what that might look like::
from django.conf.urls.defaults import * from django.conf.urls.defaults import *
urlpatterns = patterns('', urlpatterns = patterns('',
(r'^/articles/(?P\d{4})/$', 'myproject.news.views.articles.year_archive'), (r'^/articles/(?P\d{4})/$', 'myproject.news.views.articles.year_archive'),
(r'^/articles/(?P\d{4})/(?P\d{2})/$', 'myproject.news.views.articles.month_archive'), (r'^/articles/(?P\d{4})/(?P\d{2})/$', 'myproject.news.views.articles.month_archive'),
@ -205,7 +205,7 @@ and renders the template with the retrieved data. Here's an example view for
article_detail from above:: article_detail from above::
from django.models.news import articles from django.models.news import articles
def article_detail(request, year, month, article_id): def article_detail(request, year, month, article_id):
# Use the Django API to find an object matching the URL criteria. # Use the Django API to find an object matching the URL criteria.
try: try:
@ -235,9 +235,9 @@ Let's say the ``news/article_detail`` template was found. Here's what that might
look like:: look like::
{% extends "base" %} {% extends "base" %}
{% block title %}{{ article.headline }}{% endblock %} {% block title %}{{ article.headline }}{% endblock %}
{% block content %} {% block content %}
<h1>{{ article.headline }}</h1> <h1>{{ article.headline }}</h1>
<p>By {{ article.get_reporter.full_name }}</p> <p>By {{ article.get_reporter.full_name }}</p>
@ -270,7 +270,7 @@ template has to define only what's unique to that template.
Here's what the "base" template might look like:: Here's what the "base" template might look like::
<html> <html>
<head> <head>
<title>{% block title %}</title> <title>{% block title %}</title>
@ -300,7 +300,7 @@ This has been only a quick overview of Django's functionality. Some more useful
features: features:
* A caching framework that integrates with memcached or other backends. * A caching framework that integrates with memcached or other backends.
* An RSS framework that makes creating RSS feeds as easy as writing a * An RSS framework that makes creating RSS feeds as easy as writing a
small Python class. small Python class.
* More sexy automatically-generated admin features -- this overview barely * More sexy automatically-generated admin features -- this overview barely
scratched the surface scratched the surface