简体   繁体   中英

How to get fields of foreign key

In models.py:

class Comment(models.Model):
    item = models.ForeignKey(Item, on_delete=models.CASCADE, related_name='comments')
    author = models.ForeignKey(settings.AUTH_USER_MODEL, on_delete=models.CASCADE)
    body = models.TextField()
    rating = models.FloatField(null=True)
    aggregate = models.FloatField(null=True)
    date = models.DateTimeField(auto_now_add=True)


class Item(models.Model):
    id_item = models.AutoField(primary_key='true')
    item_name = models.CharField(max_length=100, null=False)
    slug = models.SlugField(max_length=250, blank=True, null=True)
    item_description = models.TextField()
    item_img = models.ImageField(blank=True, null=True, upload_to="static/item/cover/")
    tags = TaggableManager()

In views.py:

def detail(request, slug_text):
    details = Item.objects.filter(slug=slug_text)
    if details.exists():
        reviews = Comment.objects.filter(item=slug_text)
        details = details.first()
        average = reviews.aggregate(Avg("rating"))["rating_avg"]
        average = round(average, 2)
        form = CommentForm()
        if request.method == "POST":
            form = CommentForm(request.POST, author=request.user, item=details)
            if form.is_valid():
                form.save()
                return HttpResponseRedirect(slug_text)
    else:
        return HttpResponse('<h1>Trang không tồn tại</h1>')
    return render(request, 'homepage/detail.html', {'detail': details, 'form': form, 'average': average})

What if I want to get the item.slug = slug_text field in here?

reviews = Comment.objects.filter(item=slug_text)

You not far from it, to get data from a foreignkey you use double under score __ ie: to get item slug use item__slug see below

reviews = Comment.objects.filter(item__slug=slug_text)

All the best.

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM