Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
169 views
in Technique[技术] by (71.8m points)

python - How to get entry using primary key from another model in Django?


I have 2 models, "Listing" and "Watchlist". Watchlist has a primary key that is referencing Listing. For every "Watchlist" object (that has the same user X) I want to get the according "Listing" entry in form of a QuerySet.
I really struggle with this, because I don't know how to incorporate a for-loop into a queryset request.
class Watchlist(models.Model):
    listing = models.ForeignKey(Listing, on_delete=models.CASCADE, related_name="watchlists")
    user = models.ForeignKey(User, on_delete=models.CASCADE)
question from:https://stackoverflow.com/questions/65900542/how-to-get-entry-using-primary-key-from-another-model-in-django

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Reply

0 votes
by (71.8m points)

Since listing field has related_name="watchlists", we can filter using related_name like this:

Listing.objects.filter(watchlists__user = X) # X is a user instance.

Note that __ is used for field lookups. __user is for user field lookup.

If listing field does not have any related name, we can filter using model name (Watchlist) with _set to the referencing model.

Listing.objects.filter(Watchlist_set__user = X) # X is a user instance.

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
OGeek|极客中国-欢迎来到极客的世界,一个免费开放的程序员编程交流平台!开放,进步,分享!让技术改变生活,让极客改变未来! Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Click Here to Ask a Question

...