1
0
mirror of https://github.com/django/django.git synced 2025-01-22 00:02:15 +00:00

Changed tuple Mate.unique_together/permissions to lists in docs.

This commit is contained in:
Luke Plant 2019-04-22 09:31:08 +03:00 committed by Mariusz Felisiak
parent 607ff4efa3
commit 0c916255eb
4 changed files with 13 additions and 13 deletions

View File

@ -309,7 +309,7 @@ Django quotes column and table names behind the scenes.
Add, change, delete, and view permissions are automatically created for each
model. This example specifies an extra permission, ``can_deliver_pizzas``::
permissions = (("can_deliver_pizzas", "Can deliver pizzas"),)
permissions = [('can_deliver_pizzas', 'Can deliver pizzas')]
This is a list or tuple of 2-tuples in the format ``(permission_code,
human_readable_permission_name)``.
@ -408,17 +408,17 @@ Django quotes column and table names behind the scenes.
Sets of field names that, taken together, must be unique::
unique_together = (("driver", "restaurant"),)
unique_together = [['driver', 'restaurant']]
This is a tuple of tuples that must be unique when considered together.
This is a list of lists that must be unique when considered together.
It's used in the Django admin and is enforced at the database level (i.e., the
appropriate ``UNIQUE`` statements are included in the ``CREATE TABLE``
statement).
For convenience, unique_together can be a single tuple when dealing with a single
set of fields::
For convenience, ``unique_together`` can be a single list when dealing with
a single set of fields::
unique_together = ("driver", "restaurant")
unique_together = ['driver', 'restaurant']
A :class:`~django.db.models.ManyToManyField` cannot be included in
unique_together. (It's not clear what that would even mean!) If you

View File

@ -277,10 +277,10 @@ can or cannot do with ``Task`` instances, specific to your application::
class Task(models.Model):
...
class Meta:
permissions = (
permissions = [
("change_task_status", "Can change the status of tasks"),
("close_task", "Can remove a task by setting its status as closed"),
)
]
The only thing this does is create those extra permissions when you run
:djadmin:`manage.py migrate <migrate>` (the function that creates permissions

View File

@ -328,12 +328,12 @@ inherit the permissions of the concrete model they subclass::
class Person(models.Model):
class Meta:
permissions = (('can_eat_pizzas', 'Can eat pizzas'),)
permissions = [('can_eat_pizzas', 'Can eat pizzas')]
class Student(Person):
class Meta:
proxy = True
permissions = (('can_deliver_pizzas', 'Can deliver pizzas'),)
permissions = [('can_deliver_pizzas', 'Can deliver pizzas')]
>>> # Fetch the content type for the proxy model.
>>> content_type = ContentType.objects.get_for_model(Student, for_concrete_model=False)

View File

@ -367,7 +367,7 @@ Consider the following two models::
birthdate = models.DateField()
class Meta:
unique_together = (('first_name', 'last_name'),)
unique_together = [['first_name', 'last_name']]
class Book(models.Model):
name = models.CharField(max_length=100)
@ -411,7 +411,7 @@ name::
objects = PersonManager()
class Meta:
unique_together = (('first_name', 'last_name'),)
unique_together = [['first_name', 'last_name']]
Now books can use that natural key to refer to ``Person`` objects::
@ -459,7 +459,7 @@ Firstly, you need to add another method -- this time to the model itself::
objects = PersonManager()
class Meta:
unique_together = (('first_name', 'last_name'),)
unique_together = [['first_name', 'last_name']]
def natural_key(self):
return (self.first_name, self.last_name)