다음 관계를 기록한 created
필드가있는 중간 모델을 만들려고합니다.QuerySet order_by 중간 모델
모델은 다음과 같습니다 :
class Profile(models.Model):
user = models.OneToOneField(User, related_name='profile')
realname = models.CharField(max_length=20, verbose_name='真實姓名', blank=True)
nickname = models.CharField(max_length=20, verbose_name='暱稱/顯示名稱')
## the intermediate model is connected through following field ##
followings = models.ManyToManyField('self', through='FollowShip',
related_name='followers', symmetrical=False,
through_fields=('profile_from', 'profile_to'))
total_followers = models.IntegerField(default=0)
def __str__(self):
return 'Profile of User:{}'.format(self.user.username)
class FollowShip(models.Model):
profile_from = models.ForeignKey(Profile, related_name='follow_from_set')
profile_to = models.ForeignKey(Profile, related_name='follow_to_set')
created = models.DateField(auto_now_add=True, db_index=True)
def __str__(self):
return "{} follows {}".format(self.profile_from, self.profile_to)
class Meta:
unique_together = ('profile_from', 'profile_to')
그것은 잘 작동합니다. 그러나, created
필드에 의해모델의 QuerySet 순서에 액세스하려고했을 때. 오류가 발생합니다. manage.py shell
에서
는 : 중간 모델 설정이 정확하지 않은 것처럼
>>> user.profile.followings.order_by('followship__created')
Traceback (most recent call last):
File "<console>", line 1, in <module>
File "/Users/young/Desktop/env/strayvoice/lib/python3.5/site-packages/django/db/models/query.py", line 232, in __repr__
data = list(self[:REPR_OUTPUT_SIZE + 1])
File "/Users/young/Desktop/env/strayvoice/lib/python3.5/site-packages/django/db/models/query.py", line 256, in __iter__
self._fetch_all()
File "/Users/young/Desktop/env/strayvoice/lib/python3.5/site-packages/django/db/models/query.py", line 1087, in _fetch_all
self._result_cache = list(self.iterator())
File "/Users/young/Desktop/env/strayvoice/lib/python3.5/site-packages/django/db/models/query.py", line 54, in __iter__
results = compiler.execute_sql()
File "/Users/young/Desktop/env/strayvoice/lib/python3.5/site-packages/django/db/models/sql/compiler.py", line 824, in execute_sql
sql, params = self.as_sql()
File "/Users/young/Desktop/env/strayvoice/lib/python3.5/site-packages/django/db/models/sql/compiler.py", line 369, in as_sql
extra_select, order_by, group_by = self.pre_sql_setup()
File "/Users/young/Desktop/env/strayvoice/lib/python3.5/site-packages/django/db/models/sql/compiler.py", line 47, in pre_sql_setup
order_by = self.get_order_by()
File "/Users/young/Desktop/env/strayvoice/lib/python3.5/site-packages/django/db/models/sql/compiler.py", line 293, in get_order_by
field, self.query.get_meta(), default_order=asc))
File "/Users/young/Desktop/env/strayvoice/lib/python3.5/site-packages/django/db/models/sql/compiler.py", line 553, in find_ordering_name
field, targets, alias, joins, path, opts = self._setup_joins(pieces, opts, alias)
File "/Users/young/Desktop/env/strayvoice/lib/python3.5/site-packages/django/db/models/sql/compiler.py", line 586, in _setup_joins
pieces, opts, alias)
File "/Users/young/Desktop/env/strayvoice/lib/python3.5/site-packages/django/db/models/sql/query.py", line 1402, in setup_joins
names, opts, allow_many, fail_on_missing=True)
File "/Users/young/Desktop/env/strayvoice/lib/python3.5/site-packages/django/db/models/sql/query.py", line 1327, in names_to_path
"Choices are: %s" % (name, ", ".join(available)))
django.core.exceptions.FieldError: Cannot resolve keyword 'followship' into field. Choices are: follow_from_set, follow_to_set, followers, followings, id, nickname, realname, total_followers, user, user_id
것 같습니다. 그래서 내가 쿼리 followship
찾을 수 없습니다. 그러나 양측에 잘 접근 할 수 있습니다. 예를 들어 :
>>> user.profile.followings.all()
`<QuerySet [<Profile: Profile of User:222222>, <Profile: Profile of User:333333>]>`
>>> user.profile.followers.all()
`<QuerySet [<Profile: Profile of User:222222>]>`
이의 잘못 무슨 단서가 없다.
같은 오류 메시지가 표시됩니다. 중간 모델이 다른 모델을 가리키는 것과 다른 행동을하는 '자체'에 대한 m2m 관계를 나타내는 것처럼 보입니다. – JianWei