10

Tastypie で新しいインスタンスを作成しようとしていますが、外部キーでこのエラーが発生し続けます。これが私のものです:

モデル:

class SuggestionVote(models.Model):
    created_by_user = models.ForeignKey(User)
    date_created = models.DateTimeField(auto_now_add = True)
    suggestion = models.ForeignKey(Suggestion)

class Suggestion(models.Model):
    title = models.TextField(blank=True,null=True)
    created_by_user = models.ForeignKey(User)
    date_created = models.DateTimeField(auto_now_add = True)
    votes = models.IntegerField(default=0)    

    def __unicode__(self):
        return self.title

モデル リソース (独自の認証方法を使用):

class UserResource(ModelResource):
    class Meta:
        list_allowed_methods = ['get']
        queryset = User.objects.all()
        resource_name = 'user'
        authentication = MyBasicAuthentication()
        authorization = DjangoAuthorization()
class SuggestionResource(ModelResource):
    class Meta:
        list_allowed_methods = ['get']
        queryset = Suggestion.objects.all()
        resource_name = 'suggestion'
        authentication = MyBasicAuthentication()
        authorization = DjangoAuthorization()

class SuggestionVoteResource(ModelResource):
    class Meta:
        list_allowed_methods = ['get', 'post']
        detail_allowed_methods = ['get', 'post', 'put', 'delete']
        queryset = SuggestionVote.objects.all()
        resource_name = 'suggestionvote'
        authentication = MyBasicAuthentication()
        authorization = DjangoAuthorization()

jQueryを使用した私のAPI呼び出し:

var data = JSON.stringify({
    "suggestion": "/api/suggestion/1/",
    "created_by_user": "/api/user/1/"
});

$.ajax({
  url: 'http://127.0.0.1:8000/api/suggestionvote/',
  type: 'POST',
  contentType: 'application/json',
  data: data,
  dataType: 'json',
  processData: false
});

そして、私が得るエラー:

(1048、\"列 'created_by_user_id' は null にできません\")

ここで何か不足していますか?

4

2 に答える 2

14

必要なのは関係フィールドの定義だと思います。次のようなものが機能するはずです。

from tastypie import fields

class SuggestionResource(ModelResource):
    # the relationship 
    created_by_user = fields.ToOneField( UserResource, 'created_by_user', full = True )

    class Meta:
        list_allowed_methods = ['get']
        queryset = Suggestion.objects.all()
        resource_name = 'suggestion'
        authentication = MyBasicAuthentication()
        authorization = DjangoAuthorization()

私はチェックしましたが、同様のフィールド定義がないと、あなたと同じようにエラーが発生します。

于 2012-03-02T19:41:43.333 に答える
4

これも機能します。このTastypieチュートリアルでここで説明されているように

from tastypie import fields

class SuggestionResource(ModelResource):
    # the relationship 
    created_by_user = fields.ForeignKey( UserResource, 'created_by_user')

    class Meta:
        list_allowed_methods = ['get']
        queryset = Suggestion.objects.all()
        resource_name = 'suggestion'
        authentication = MyBasicAuthentication()
        authorization = DjangoAuthorization()
于 2013-02-10T11:23:25.290 に答える