質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

87.59%

ValueError: Field 'id' expected a number but got

解決済

回答 2

投稿

  • 評価
  • クリップ 0
  • VIEW 831
退会済みユーザー

退会済みユーザー

前提・実現したいこと

現在Djangoにて投稿・コメント機能を実装しているのですが、migrateを行えずこのようなエラーが発生してしまいました。

発生している問題・エラーメッセージ

ValueError: Field 'id' expected a number but got '退会済みのユーザー'.

該当のソースコード

class UserManager(BaseUserManager):

    def _create_user(self, email, password, is_staff, is_superuser, **extra_fields):
        if not email:
            raise ValueError('Users must have an email address')
        now = timezone.now()
        email = self.normalize_email(email)
        user = self.model(
            email=email,
            is_staff=is_staff,
            is_active=True,
            is_superuser=is_superuser,
            last_login=now,
            date_joined=now,
            **extra_fields
        )
        user.set_password(password)
        user.save(using=self._db)
        return user

    def create_user(self, email, password, **extra_fields):
        return self._create_user(email, password, False, False, **extra_fields)

    def create_superuser(self, email, password, **extra_fields):
        user = self._create_user(email, password, True, True, **extra_fields)
        user.save(using=self._db)
        return user

class User(AbstractBaseUser, PermissionsMixin):
    name = models.CharField(max_length=50, null=True, blank=True)
    email = models.EmailField(max_length=254,unique=True)
    username= models.CharField(max_length=30,null=False, blank=True)
    user_id = models.CharField(max_length=30,null=False, blank=True)
    profile_image=models.ImageField(upload_to='media',null=True)
    self_introduction = models.TextField(max_length=300, null=False, blank=True)
    is_staff = models.BooleanField(default=False)
    is_superuser = models.BooleanField(default=False)
    is_active = models.BooleanField(default=True)
    last_login = models.DateTimeField(null=True,blank=True)
    date_joined = models.DateTimeField(auto_now_add=True)


    USERNAME_FIELD = 'email'
    EMAIL_FIELD = 'email'
    REQUIRED_FIELDS = []

    objects = UserManager()

    def get_absolute_url(self):
        return "/users/%i/" % self.pk

    def __str__(self):
                return self.username
from django.db import models
from accounts.models import User
from django.utils import timezone


class Post(models.Model):#投稿モデル
    username=models.ForeignKey(User,on_delete=models.SET_DEFAULT,default='退会済みのユーザー')
    title=models.CharField(max_length=100,blank=False,null=False)
    post_img1=models.ImageField(upload_to='post1',blank=True,null=True)
    post_img2=models.ImageField(upload_to='post2',blank=True,null=True)
    post_img3=models.ImageField(upload_to='post3',blank=True,null=True)
    text=models.TextField(max_length=5000,blank=False,null=False)
    add_time=models.DateTimeField(default=timezone.now)
    tag = models.TextField(max_length=200,blank=True,null=True)

    def __str__(self):
        return self.title


class Comment(models.Model):#コメントモデル
    target_post=models.ForeignKey(Post,on_delete=models.CASCADE)
    username=models.ForeignKey(User,on_delete=models.SET_DEFAULT,default='退会済みのユーザー')
    text=models.TextField(max_length=500)
    add_time=models.DateTimeField(default=timezone.now)

    def __str__(self):
        return self.text

class Reply(models.Model):#返信モデル
    target_comment=models.ForeignKey('Comment',on_delete=models.CASCADE)
    username=models.ForeignKey(User,on_delete=models.SET_DEFAULT,default='退会済みのユーザー')
    text=models.TextField(max_length=500)
    time=models.DateTimeField(default=timezone.now)

    def __str__(self):
        return self.text
from django.forms import ModelForm
from post.models import Post, Comment,Reply


class PostCreateForm(ModelForm):
    class Meta:
        model=Post
        fields=[
             'title','text','post_img1','post_img2','post_img3','tag',
        ]

class CommentForm(ModelForm):
    class Meta:
        model=Comment
        fields=[
            'text'
        ]

class ReplyForm(ModelForm):
    class Meta:
        model=Reply
        fields=[
            'text'
        ]
from django.contrib.auth.mixins import LoginRequiredMixin
from django.shortcuts import redirect, get_object_or_404
from post.forms import PostCreateForm,CommentForm,ReplyForm
from django.urls import reverse_lazy
from post.models import Post,Comment,Reply
from django.views.generic import (
    CreateView,
    DetailView,

)



class PostCreateView(CreateView,LoginRequiredMixin):#投稿機能
    template_name = 'post/post_create.html'
    form_class = PostCreateForm
    success_url = reverse_lazy('home')

    def form_valid(self, form):
        form.instance.username=self.request.user
        return super().form_valid(form)


class CommentView(CreateView,LoginRequiredMixin):#コメント機能
    template_name = 'post/comment.html'
    model = Comment
    form_class = CommentForm


    def form_valid(self, form ):
        form.instance.username =self.request.user
        post_pk = self.kwargs['pk']
        post = get_object_or_404(Post, pk=post_pk)
        comment = form.save(commit=False)
        comment.target_post= post
        comment.save()
        return redirect('detail',pk=post_pk)


    def get_context_data(self, **kwargs):
        context = super().get_context_data(**kwargs)
        context['post'] = get_object_or_404(Post, pk=self.kwargs['pk'])
        return context


class ReplyCreateView(CreateView,LoginRequiredMixin):#返信機能
    template_name = 'post/reply.html'
    model = Reply
    form_class = ReplyForm

    def form_valid(self, form):
        form.instance.username = self.request.user
        comment_pk = self.kwargs['pk']
        comment = get_object_or_404(Comment, pk=comment_pk)
        reply = form.save(commit=False)
        reply.target_comment = comment
        reply.save()
        return redirect('detail', pk=comment.target_post.pk)

    def get_context_data(self, **kwargs):
        context = super().get_context_data(**kwargs)
        comment_pk = self.kwargs['pk']
        comment = get_object_or_404(Comment, pk=comment_pk)
        context['post'] = comment.target_post
        return context



class PostDetailView(DetailView):#投稿の詳細
    template_name = 'post/post_detail.html'
    model = Post

試したこと

一度この書き方でサイトをリリースしているのですが今回は何故かエラーが発生してしまいました。idの取得と記載されていたのでpkをidに変更するなどしましたが同じ動作しませんでした。

補足情報(FW/ツールのバージョンなど)

前回よりの変更点としてsqlite3→postgressqlに変更

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 2

check解決した方法

0

自己解決しました。postgresのnotnull制約の関係上on_delete=models.SET_DEFAULT,defaultを使うと削除済みユーザーがnullを返す為どうしてもエラーが発生してしまいまみたいです。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

0

google翻訳
ValueError: フィールド「id」は数値を期待していましたが、'退会済みのユーザー'.

ということですよ。
エラーのでた行にでてくる変数のナカミをチェックしてみたらどーでしょう

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 87.59%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る