2006-05-02 01:31:56 +00:00
|
|
|
"""
|
2014-09-24 12:13:13 +07:00
|
|
|
Many-to-many and many-to-one relationships to the same table
|
2006-05-02 01:31:56 +00:00
|
|
|
|
2006-05-31 19:23:07 +00:00
|
|
|
Make sure to set ``related_name`` if you use relationships to the same table.
|
2006-05-02 01:31:56 +00:00
|
|
|
"""
|
2012-06-07 18:08:47 +02:00
|
|
|
from __future__ import unicode_literals
|
2006-05-02 01:31:56 +00:00
|
|
|
|
|
|
|
from django.db import models
|
2012-07-20 14:48:51 +02:00
|
|
|
from django.utils import six
|
2012-08-12 12:32:08 +02:00
|
|
|
from django.utils.encoding import python_2_unicode_compatible
|
2006-05-02 01:31:56 +00:00
|
|
|
|
2011-10-13 18:04:12 +00:00
|
|
|
|
2006-05-02 01:31:56 +00:00
|
|
|
class User(models.Model):
|
2007-08-05 05:14:46 +00:00
|
|
|
username = models.CharField(max_length=20)
|
2006-05-02 01:31:56 +00:00
|
|
|
|
2013-11-02 23:36:09 -05:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
@python_2_unicode_compatible
|
2006-05-02 01:31:56 +00:00
|
|
|
class Issue(models.Model):
|
|
|
|
num = models.IntegerField()
|
|
|
|
cc = models.ManyToManyField(User, blank=True, related_name='test_issue_cc')
|
|
|
|
client = models.ForeignKey(User, related_name='test_issue_client')
|
2006-05-31 19:23:07 +00:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
def __str__(self):
|
2012-07-20 14:48:51 +02:00
|
|
|
return six.text_type(self.num)
|
2006-05-31 19:10:43 +00:00
|
|
|
|
2006-05-02 01:31:56 +00:00
|
|
|
class Meta:
|
|
|
|
ordering = ('num',)
|
2011-08-24 03:51:33 +00:00
|
|
|
|
2013-11-02 23:36:09 -05:00
|
|
|
|
2011-10-13 18:04:12 +00:00
|
|
|
class UnicodeReferenceModel(models.Model):
|
2012-06-07 18:08:47 +02:00
|
|
|
others = models.ManyToManyField("UnicodeReferenceModel")
|