2006-05-02 01:31:56 +00:00
|
|
|
"""
|
2014-09-24 05:13:13 +00: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 16:08:47 +00:00
|
|
|
from __future__ import unicode_literals
|
2006-05-02 01:31:56 +00:00
|
|
|
|
|
|
|
from django.db import models
|
2012-07-20 12:48:51 +00:00
|
|
|
from django.utils import six
|
2012-08-12 10:32:08 +00: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-03 04:36:09 +00:00
|
|
|
|
2012-08-12 10:32:08 +00: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')
|
2015-07-22 14:43:21 +00:00
|
|
|
client = models.ForeignKey(User, models.CASCADE, related_name='test_issue_client')
|
2006-05-31 19:23:07 +00:00
|
|
|
|
2012-08-12 10:32:08 +00:00
|
|
|
def __str__(self):
|
2012-07-20 12:48:51 +00: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-03 04:36:09 +00:00
|
|
|
|
2011-10-13 18:04:12 +00:00
|
|
|
class UnicodeReferenceModel(models.Model):
|
2012-06-07 16:08:47 +00:00
|
|
|
others = models.ManyToManyField("UnicodeReferenceModel")
|