複数のテーブル間の関係にまたがる特定の FK フィールドのセットを持つ ValuesQuerySet を取得しようとしています。このクエリを django シェルで実行しても、問題はありません。しかし、開発サーバーで実行すると、Django はこれらの FK フィールドのすべてではなく一部で FieldDoesNotExist エラーを返します。
関連するモデルは次のとおりです (私は標準の Django User モデルを使用しています)。
class Profile(models.Model):
user = models.OneToOneField(User)
first_name = models.CharField(max_length=150,null=True)
middle_name = models.CharField(max_length=150,null=True)
last_name = models.CharField(max_length=150,null=True)
headline = models.TextField(null=True)
connections = models.ManyToManyField('self',through="Connection",symmetrical=False,related_name="connections+")
status = models.CharField(max_length=15,default="active")
class Position(models.Model):
entity = models.ForeignKey(Entity,related_name="positions")
person = models.ForeignKey(User,related_name="positions")
careers = models.ManyToManyField("Career",related_name="positions")
title = models.CharField(max_length=150,null=True)
summary = models.CharField(max_length=450,null=True)
description = models.TextField(null=True)
current = models.BooleanField(default=True)
start_date = models.DateField(null=True)
end_date = models.DateField(null=True)
type = models.CharField(max_length=450,null=True)
degree = models.CharField(max_length=450,null=True)
field = models.CharField(max_length=450,null=True)
status = models.CharField(max_length=15,default="active")
created = models.DateTimeField(auto_now_add=True, null=True)
updated = models.DateTimeField(auto_now=True, null=True)
class Entity(models.Model):
name = models.CharField(max_length=450)
created = models.DateTimeField(auto_now_add=True)
updated = models.DateTimeField(auto_now=True)
status = models.CharField(max_length=15,default="active")
class Picture(models.Model):
person = models.ForeignKey(Profile,related_name="pictures")
pic = models.ImageField(max_length=450,upload_to=_get_picture_path)
source = models.CharField(max_length=45,null=True)
description = models.TextField(null=True)
license = models.TextField(null=True)
created = models.DateTimeField(auto_now_add=True)
updated = models.DateTimeField(auto_now=True)
status = models.CharField(max_length=15,default="active")
1 つのビューでは、わずかに異なる 2 つのクエリを実行して、これらの接続されたテーブルから取得した情報を使用してユーザーのスライスを取得します (1 つはユーザー ID の配列に制限されていますuser_ids
)。
some_people = User.objects.values('id','profile__headline','profile__first_name','profile__last_name','profile__pictures__pic','positions__entity__id','positions__entity__name').filter(id__in=user_ids).annotate(no_of_pos=Count('positions__id')).order_by('-no_of_pos')
all_people = User.objects.select_related('positions','profile').values('id','profile__headline','profile__first_name','profile__last_name','profile__pictures__pic','positions__entity__id','positions__entity__name').annotate(no_of_pos=Count('positions__id')).order_by('-no_of_pos')
これらの機能はほとんど同じで、1 つは定義済みのユーザー セット (id で識別) に制限され、もう 1 つは制限されていません。これらの結果が一部の情報の重複を返すことはわかっていますが、後のステップで、この情報をテンプレート用のわずかに異なる辞書に組み立てるときに対処します。
これらのクエリをシェルで実行しても問題はありません。クエリには時間がかからず、すべてのフィールドが適切に評価されます。ただし、開発サーバーは次のエラーを返します。
User has no field named 'headline'
「profile_ headline」、「profile _pictures_ pic」、「positions _entity_ name」が含まれている限り、同様のエラーが返されます。このエラーは私には意味がありません。これらのフィールドは存在しますが、ユーザー オブジェクトにはありません。ユーザー オブジェクトでは呼び出されません。さらに、なぜこれらのフィールドだけなのですか? 「profile _last_name」、「profile__first_name」、および「positions_ entity _id」はすべて同じビンに分類されるはずです。
これを解決するのを手伝ってください - 何かアイデアはありますか?
Mac OS X で Python 2.6 を使用して Django 1.4.2 を実行しています。