From d5c9e194036d44785eda0c621725a2862e8aa6fe Mon Sep 17 00:00:00 2001 From: Adrian Holovaty Date: Fri, 19 May 2006 05:07:33 +0000 Subject: [PATCH] Small cleanups to docs/model-api.txt and docs/django-admin.txt git-svn-id: http://code.djangoproject.com/svn/django/trunk@2945 bcc190cf-cafb-0310-a4f2-bffc1f526a37 --- docs/django-admin.txt | 46 ++++++++++++++++++++++--------------------- docs/model-api.txt | 36 +++++++++++++++++++++------------ 2 files changed, 47 insertions(+), 35 deletions(-) diff --git a/docs/django-admin.txt b/docs/django-admin.txt index 19abbed626..8cb7897503 100644 --- a/docs/django-admin.txt +++ b/docs/django-admin.txt @@ -177,13 +177,12 @@ Port 7000 on IP address 1.2.3.4:: django-admin.py runserver 1.2.3.4:7000 -Serving static files with the development server: -~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ +Serving static files with the development server +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ -By default, the development server will not be able to serve any static files -for your site (such as CSS files, images, things under MEDIA_ROOT_URL and so -forth). If you wish to configure your project to handle static media via the -development server, read the instructions in the `serving static files`_ +By default, the development server doesn't serve any static files for your site +(such as CSS files, images, things under ``MEDIA_ROOT_URL`` and so forth). If +you want to configure Django to serve static media, read the `serving static files`_ documentation. .. _serving static files: http://www.djangoproject.com/documentation/static_files/ @@ -212,7 +211,7 @@ sqlall [appname appname ...] Prints the CREATE TABLE and initial-data SQL statements for the given appnames. Refer to the description of ``sqlinitialdata`` for an explanation of how to -specify seed data. +specify initial data. sqlclear [appname appname ...] -------------------------------------- @@ -229,13 +228,17 @@ sqlinitialdata [appname appname ...] Prints the initial INSERT SQL statements for the given appnames. -This command will read any files under ``/sql/`` that have the same -name as the lower-cased version of a model name (so if your app includes a -model called ``Poll``, the file ``poll.sql`` will be read). These files are -expected to be valid SQL files and their contents are piped into the database -after all of the models' table creation statements have been executed. This -can be used to populate the tables with any necessary initial records or test -data. +For each model in each specified app, this command looks for the file +``/sql/.sql``, where ```` is the given appname and +```` is the model's name in lowercase. For example, if you have an +app ``news`` that includes a ``Story`` model, ``sqlinitialdata`` will attempt +to read a file ``news/sql/story.sql`` and append it to the output of this +command. + +Each of the SQL files, if given, is expected to contain valid SQL. The SQL +files are piped directly into the database after all of the models' +table-creation statements have been executed. Use this SQL hook to populate +tables with any necessary initial records, SQL functions or test data. sqlreset [appname appname ...] -------------------------------------- @@ -265,17 +268,16 @@ current directory. syncdb ------ -Creates the database tables for all apps in INSTALLED_APPS whose tables +Creates the database tables for all apps in ``INSTALLED_APPS`` whose tables have not already been created. -This is the command to use when you have added new applications to your -project and want to install them in the database. This includes any -applications shipped with Django that might be in INSTALLED_APPS by default. -When you start a new project, run this command to install the default apps. +Use this command when you've added new applications to your project and want to +install them in the database. This includes any apps shipped with Django that +might be in ``INSTALLED_APPS`` by default. When you start a new project, run +this command to install the default apps. -If you are installing the ``django.contrib.auth`` application, ``sycndb`` will -give you the option of creating a superuser immediately, which will permit you -to log into the admin interface, for example, when the time comes. +If you're installing the ``django.contrib.auth`` application, ``syncdb`` will +give you the option of creating a superuser immediately. validate -------- diff --git a/docs/model-api.txt b/docs/model-api.txt index de971f7e74..6c674cb1aa 100644 --- a/docs/model-api.txt +++ b/docs/model-api.txt @@ -1632,20 +1632,30 @@ read, in part:: #... ) -Seeding models with initial data -================================ +Providing initial SQL data +========================== -Sometimes, once the database tables for a model are created, you will want to -populate them with some default records or perhaps some testing data. For each -model you have like this, create a file named after the lower-cased version of -the model's name, with an extension of ``.sql``. Put this file in a directory -called ``sql/`` under your application directory (so, ``myapp/sql/poll.sql`` -for ``Poll`` model in the ``myapp`` application). +Django provides a hook for passing the database arbitrary SQL that's executed +just after the CREATE TABLE statements. Use this hook, for example, if you want +to populate default records, or create SQL functions, automatically. -This file should contain valid SQL statements that can be executed to create -the initial data you would like to insert. These files are read by the -``sqlinitialdata``, ``sqlreset``, ``sqlall`` and ``reset`` commands in -``manage.py``. Refer to the `manage.py documentation`_ for more -information. +The hook is simple: Django just looks for a file called +``/sql/.sql``, where ```` is your app directory and +```` is the model's name in lowercase. + +In the ``Person`` example model at the top of this document, assuming it lives +in an app called ``myapp``, you could add arbitrary SQL to the file +``myapp/sql/person.sql``. Here's an example of what the file might contain:: + + INSERT INTO myapp_person (first_name, last_name) VALUES ('John', 'Lennon'); + INSERT INTO myapp_person (first_name, last_name) VALUES ('Paul', 'McCartney'); + +Each SQL file, if given, is expected to contain valid SQL. The SQL files are +piped directly into the database after all of the models' table-creation +statements have been executed. + +The SQL files are read by the ``sqlinitialdata``, ``sqlreset``, ``sqlall`` and +``reset`` commands in ``manage.py``. Refer to the `manage.py documentation`_ +for more information. .. _`manage.py documentation`: http://www.djangoproject.com/documentation/django_admin/#sqlinitialdata-appname-appname