mirror of
https://github.com/django/django.git
synced 2025-10-24 14:16:09 +00:00
Fixed #21479 -- Favor 'migrate' over 'syncdb' in the docs.
This commit is contained in:
committed by
Baptiste Mispelon
parent
b6a6cf4ab7
commit
27f04e79b1
@@ -45,7 +45,7 @@ Take a look at Django's support for :mod:`schema migrations
|
|||||||
|
|
||||||
If you don't mind clearing data, your project's ``manage.py`` utility has a
|
If you don't mind clearing data, your project's ``manage.py`` utility has a
|
||||||
:djadmin:`flush` option to reset the database to the state it was in
|
:djadmin:`flush` option to reset the database to the state it was in
|
||||||
immediately after :djadmin:`syncdb` was executed.
|
immediately after :djadmin:`migrate` was executed.
|
||||||
|
|
||||||
Do Django models support multiple-column primary keys?
|
Do Django models support multiple-column primary keys?
|
||||||
------------------------------------------------------
|
------------------------------------------------------
|
||||||
|
@@ -676,8 +676,9 @@ For example::
|
|||||||
def get_internal_type(self):
|
def get_internal_type(self):
|
||||||
return 'CharField'
|
return 'CharField'
|
||||||
|
|
||||||
No matter which database backend we are using, this will mean that ``syncdb``
|
No matter which database backend we are using, this will mean that
|
||||||
and other SQL commands create the right column type for storing a string.
|
:djadmin:`migrate` and other SQL commands create the right column type for
|
||||||
|
storing a string.
|
||||||
|
|
||||||
If :meth:`.get_internal_type` returns a string that is not known to Django for
|
If :meth:`.get_internal_type` returns a string that is not known to Django for
|
||||||
the database backend you are using -- that is, it doesn't appear in
|
the database backend you are using -- that is, it doesn't appear in
|
||||||
|
@@ -78,9 +78,9 @@ Automatically loading initial data fixtures
|
|||||||
-------------------------------------------
|
-------------------------------------------
|
||||||
|
|
||||||
If you create a fixture named ``initial_data.[xml/yaml/json]``, that fixture will
|
If you create a fixture named ``initial_data.[xml/yaml/json]``, that fixture will
|
||||||
be loaded every time you run :djadmin:`syncdb`. This is extremely convenient,
|
be loaded every time you run :djadmin:`migrate`. This is extremely convenient,
|
||||||
but be careful: remember that the data will be refreshed *every time* you run
|
but be careful: remember that the data will be refreshed *every time* you run
|
||||||
:djadmin:`syncdb`. So don't use ``initial_data`` for data you'll want to edit.
|
:djadmin:`migrate`. So don't use ``initial_data`` for data you'll want to edit.
|
||||||
|
|
||||||
Where Django finds fixture files
|
Where Django finds fixture files
|
||||||
--------------------------------
|
--------------------------------
|
||||||
@@ -104,7 +104,7 @@ Providing initial SQL data
|
|||||||
==========================
|
==========================
|
||||||
|
|
||||||
Django provides a hook for passing the database arbitrary SQL that's executed
|
Django provides a hook for passing the database arbitrary SQL that's executed
|
||||||
just after the CREATE TABLE statements when you run :djadmin:`syncdb`. You can
|
just after the CREATE TABLE statements when you run :djadmin:`migrate`. You can
|
||||||
use this hook to populate default records, or you could also create SQL
|
use this hook to populate default records, or you could also create SQL
|
||||||
functions, views, triggers, etc.
|
functions, views, triggers, etc.
|
||||||
|
|
||||||
|
@@ -263,9 +263,9 @@ that, run the following command:
|
|||||||
|
|
||||||
.. code-block:: bash
|
.. code-block:: bash
|
||||||
|
|
||||||
$ python manage.py syncdb
|
$ python manage.py migrate
|
||||||
|
|
||||||
The :djadmin:`syncdb` command looks at the :setting:`INSTALLED_APPS` setting
|
The :djadmin:`migrate` command looks at the :setting:`INSTALLED_APPS` setting
|
||||||
and creates any necessary database tables according to the database settings
|
and creates any necessary database tables according to the database settings
|
||||||
in your :file:`mysite/settings.py` file. You'll see a message for each
|
in your :file:`mysite/settings.py` file. You'll see a message for each
|
||||||
database table it creates, and you'll get a prompt asking you if you'd like to
|
database table it creates, and you'll get a prompt asking you if you'd like to
|
||||||
@@ -281,8 +281,8 @@ display the tables Django created.
|
|||||||
Like we said above, the default applications are included for the common
|
Like we said above, the default applications are included for the common
|
||||||
case, but not everybody needs them. If you don't need any or all of them,
|
case, but not everybody needs them. If you don't need any or all of them,
|
||||||
feel free to comment-out or delete the appropriate line(s) from
|
feel free to comment-out or delete the appropriate line(s) from
|
||||||
:setting:`INSTALLED_APPS` before running :djadmin:`syncdb`. The
|
:setting:`INSTALLED_APPS` before running :djadmin:`migrate`. The
|
||||||
:djadmin:`syncdb` command will only create tables for apps in
|
:djadmin:`migrate` command will only create tables for apps in
|
||||||
:setting:`INSTALLED_APPS`.
|
:setting:`INSTALLED_APPS`.
|
||||||
|
|
||||||
.. _creating-models:
|
.. _creating-models:
|
||||||
@@ -510,17 +510,17 @@ If you're interested, also run the following commands:
|
|||||||
Looking at the output of those commands can help you understand what's actually
|
Looking at the output of those commands can help you understand what's actually
|
||||||
happening under the hood.
|
happening under the hood.
|
||||||
|
|
||||||
Now, run :djadmin:`syncdb` again to create those model tables in your database:
|
Now, run :djadmin:`migrate` again to create those model tables in your database:
|
||||||
|
|
||||||
.. code-block:: bash
|
.. code-block:: bash
|
||||||
|
|
||||||
$ python manage.py syncdb
|
$ python manage.py migrate
|
||||||
|
|
||||||
The :djadmin:`syncdb` command runs the SQL from :djadmin:`sqlall` on your
|
The :djadmin:`migrate` command runs the SQL from :djadmin:`sqlall` on your
|
||||||
database for all apps in :setting:`INSTALLED_APPS` that don't already exist in
|
database for all apps in :setting:`INSTALLED_APPS` that don't already exist in
|
||||||
your database. This creates all the tables, initial data and indexes for any
|
your database. This creates all the tables, initial data and indexes for any
|
||||||
apps you've added to your project since the last time you ran syncdb.
|
apps you've added to your project since the last time you ran :djadmin:`migrate`.
|
||||||
:djadmin:`syncdb` can be called as often as you like, and it will only ever
|
:djadmin:`migrate` can be called as often as you like, and it will only ever
|
||||||
create the tables that don't exist.
|
create the tables that don't exist.
|
||||||
|
|
||||||
Read the :doc:`django-admin.py documentation </ref/django-admin>` for full
|
Read the :doc:`django-admin.py documentation </ref/django-admin>` for full
|
||||||
|
@@ -52,7 +52,7 @@ Example
|
|||||||
PRIMEM["Greenwich",0],
|
PRIMEM["Greenwich",0],
|
||||||
UNIT["Degree",0.017453292519943295]]
|
UNIT["Degree",0.017453292519943295]]
|
||||||
|
|
||||||
2. Now we define our corresponding Django model (make sure to use ``syncdb``)::
|
2. Now we define our corresponding Django model (make sure to use :djadmin:`migrate`)::
|
||||||
|
|
||||||
from django.contrib.gis.db import models
|
from django.contrib.gis.db import models
|
||||||
|
|
||||||
|
@@ -262,8 +262,8 @@ argument. Use an integer representing the coordinate system's EPSG code.
|
|||||||
|
|
||||||
__ http://en.wikipedia.org/wiki/SRID
|
__ http://en.wikipedia.org/wiki/SRID
|
||||||
|
|
||||||
Run ``syncdb``
|
Run ``migrate``
|
||||||
--------------
|
---------------
|
||||||
|
|
||||||
After defining your model, you need to sync it with the database. First,
|
After defining your model, you need to sync it with the database. First,
|
||||||
let's look at the SQL that will generate the table for the
|
let's look at the SQL that will generate the table for the
|
||||||
@@ -296,14 +296,14 @@ This command should produce the following output:
|
|||||||
CREATE INDEX "world_worldborder_mpoly_id" ON "world_worldborder" USING GIST ( "mpoly" GIST_GEOMETRY_OPS );
|
CREATE INDEX "world_worldborder_mpoly_id" ON "world_worldborder" USING GIST ( "mpoly" GIST_GEOMETRY_OPS );
|
||||||
COMMIT;
|
COMMIT;
|
||||||
|
|
||||||
If this looks correct, run ``syncdb`` to create this table in the database::
|
If this looks correct, run :djadmin:`migrate` to create this table in the database::
|
||||||
|
|
||||||
$ python manage.py syncdb
|
$ python manage.py migrate
|
||||||
Creating table world_worldborder
|
Creating table world_worldborder
|
||||||
Installing custom SQL for world.WorldBorder model
|
Installing custom SQL for world.WorldBorder model
|
||||||
|
|
||||||
The ``syncdb`` command may also prompt you to create an admin user. Either
|
The :djadmin:`migrate` command may also prompt you to create an admin user.
|
||||||
do so now, or later by running ``django-admin.py createsuperuser``.
|
Either do so now, or later by running ``django-admin.py createsuperuser``.
|
||||||
|
|
||||||
Importing Spatial Data
|
Importing Spatial Data
|
||||||
======================
|
======================
|
||||||
@@ -742,7 +742,7 @@ Start up the Django development server:
|
|||||||
$ python manage.py runserver
|
$ python manage.py runserver
|
||||||
|
|
||||||
Finally, browse to ``http://localhost:8000/admin/``, and log in with the admin
|
Finally, browse to ``http://localhost:8000/admin/``, and log in with the admin
|
||||||
user created after running ``syncdb``. Browse to any of the ``WorldBorder``
|
user created after running :djadmin:`migrate`. Browse to any of the ``WorldBorder``
|
||||||
entries -- the borders may be edited by clicking on a polygon and dragging
|
entries -- the borders may be edited by clicking on a polygon and dragging
|
||||||
the vertexes to the desired position.
|
the vertexes to the desired position.
|
||||||
|
|
||||||
|
@@ -263,7 +263,7 @@ Django quotes column and table names behind the scenes.
|
|||||||
Defaults to ``('add', 'change', 'delete')``. You may customize this list,
|
Defaults to ``('add', 'change', 'delete')``. You may customize this list,
|
||||||
for example, by setting this to an empty list if your app doesn't require
|
for example, by setting this to an empty list if your app doesn't require
|
||||||
any of the default permissions. It must be specified on the model before
|
any of the default permissions. It must be specified on the model before
|
||||||
the model is created by :djadmin:`syncdb` in order to prevent any omitted
|
the model is created by :djadmin:`migrate` in order to prevent any omitted
|
||||||
permissions from being created.
|
permissions from being created.
|
||||||
|
|
||||||
``proxy``
|
``proxy``
|
||||||
|
@@ -73,14 +73,14 @@ If you attempt to access a database that you haven't defined in your
|
|||||||
Synchronizing your databases
|
Synchronizing your databases
|
||||||
============================
|
============================
|
||||||
|
|
||||||
The :djadmin:`syncdb` management command operates on one database at a
|
The :djadmin:`migrate` management command operates on one database at a
|
||||||
time. By default, it operates on the ``default`` database, but by
|
time. By default, it operates on the ``default`` database, but by
|
||||||
providing a :djadminopt:`--database` argument, you can tell syncdb to
|
providing a :djadminopt:`--database` argument, you can tell :djadmin:`migrate`
|
||||||
synchronize a different database. So, to synchronize all models onto
|
to synchronize a different database. So, to synchronize all models onto
|
||||||
all databases in our example, you would need to call::
|
all databases in our example, you would need to call::
|
||||||
|
|
||||||
$ ./manage.py syncdb
|
$ ./manage.py migrate
|
||||||
$ ./manage.py syncdb --database=users
|
$ ./manage.py migrate --database=users
|
||||||
|
|
||||||
If you don't want every application to be synchronized onto a
|
If you don't want every application to be synchronized onto a
|
||||||
particular database, you can define a :ref:`database
|
particular database, you can define a :ref:`database
|
||||||
@@ -97,7 +97,7 @@ Using other management commands
|
|||||||
-------------------------------
|
-------------------------------
|
||||||
|
|
||||||
The other ``django-admin.py`` commands that interact with the database
|
The other ``django-admin.py`` commands that interact with the database
|
||||||
operate in the same way as :djadmin:`syncdb` -- they only ever operate
|
operate in the same way as :djadmin:`migrate` -- they only ever operate
|
||||||
on one database at a time, using :djadminopt:`--database` to control
|
on one database at a time, using :djadminopt:`--database` to control
|
||||||
the database used.
|
the database used.
|
||||||
|
|
||||||
@@ -681,7 +681,7 @@ how you can split these models across databases:
|
|||||||
in the same database as ``sites``.
|
in the same database as ``sites``.
|
||||||
|
|
||||||
In addition, some objects are automatically created just after
|
In addition, some objects are automatically created just after
|
||||||
:djadmin:`syncdb` creates a table to hold them in a database:
|
:djadmin:`migrate` creates a table to hold them in a database:
|
||||||
|
|
||||||
- a default ``Site``,
|
- a default ``Site``,
|
||||||
- a ``ContentType`` for each model (including those not stored in that
|
- a ``ContentType`` for each model (including those not stored in that
|
||||||
@@ -693,7 +693,7 @@ For common setups with multiple databases, it isn't useful to have these
|
|||||||
objects in more than one database. Common setups include master / slave and
|
objects in more than one database. Common setups include master / slave and
|
||||||
connecting to external databases. Therefore, it's recommended:
|
connecting to external databases. Therefore, it's recommended:
|
||||||
|
|
||||||
- either to run :djadmin:`syncdb` only for the default database;
|
- either to run :djadmin:`migrate` only for the default database;
|
||||||
- or to write :ref:`database router<topics-db-multi-db-routing>` that allows
|
- or to write :ref:`database router<topics-db-multi-db-routing>` that allows
|
||||||
synchronizing these three models only to one database.
|
synchronizing these three models only to one database.
|
||||||
|
|
||||||
|
@@ -1241,7 +1241,7 @@ Here's specifically what will happen:
|
|||||||
|
|
||||||
* At the start of each test case, before ``setUp()`` is run, Django will
|
* At the start of each test case, before ``setUp()`` is run, Django will
|
||||||
flush the database, returning the database to the state it was in
|
flush the database, returning the database to the state it was in
|
||||||
directly after :djadmin:`syncdb` was called.
|
directly after :djadmin:`migrate` was called.
|
||||||
|
|
||||||
* Then, all the named fixtures are installed. In this example, Django will
|
* Then, all the named fixtures are installed. In this example, Django will
|
||||||
install any JSON fixture named ``mammals``, followed by any fixture named
|
install any JSON fixture named ``mammals``, followed by any fixture named
|
||||||
|
Reference in New Issue
Block a user