Django的數(shù)據(jù)模型訪問多對多鍵值的方法
這里先來借用一個書本(book)的數(shù)據(jù)模型作為例子:
from django.db import models
class Publisher(models.Model):
name = models.CharField(max_length=30)
address = models.CharField(max_length=50)
city = models.CharField(max_length=60)
state_province = models.CharField(max_length=30)
country = models.CharField(max_length=50)
website = models.URLField()
def __unicode__(self):
return self.name
class Author(models.Model):
first_name = models.CharField(max_length=30)
last_name = models.CharField(max_length=40)
email = models.EmailField()
def __unicode__(self):
return u'%s %s' % (self.first_name, self.last_name)
class Book(models.Model):
title = models.CharField(max_length=100)
authors = models.ManyToManyField(Author)
publisher = models.ForeignKey(Publisher)
publication_date = models.DateField()
def __unicode__(self):
return self.title
訪問多對多值(Many-to-Many Values)
多對多和外鍵工作方式相同,只不過我們處理的是QuerySet而不是模型實例。 例如,這里是如何查看書籍的作者:
>>> b = Book.objects.get(id=50) >>> b.authors.all() [<Author: Adrian Holovaty>, <Author: Jacob Kaplan-Moss>] >>> b.authors.filter(first_name='Adrian') [<Author: Adrian Holovaty>] >>> b.authors.filter(first_name='Adam') []
反向查詢也可以。 要查看一個作者的所有書籍,使用author.book_set ,就如這樣:
>>> a = Author.objects.get(first_name='Adrian', last_name='Holovaty') >>> a.book_set.all() [<Book: The Django Book>, <Book: Adrian's Other Book>]
這里,就像使用 ForeignKey字段一樣,屬性名book_set是在數(shù)據(jù)模型(model)名后追加_set。
相關文章
python3 tkinter實現(xiàn)點擊一個按鈕跳出另一個窗口的方法
今天小編就為大家分享一篇python3 tkinter實現(xiàn)點擊一個按鈕跳出另一個窗口的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-06-06
編寫Python腳本把sqlAlchemy對象轉換成dict的教程
這篇文章主要介紹了編寫Python腳本把sqlAlchemy對象轉換成dict的教程,主要是基于Python的model類構建一個轉換的方法,需要的朋友可以參考下2015-05-05
Python實現(xiàn)統(tǒng)計單詞出現(xiàn)的個數(shù)
這篇文章主要介紹了Python實現(xiàn)統(tǒng)計單詞出現(xiàn)的個數(shù),本文給出了實現(xiàn)代碼以及使用方法,需要的朋友可以參考下2015-05-05
python中判斷數(shù)字是否為質數(shù)的實例講解
在本篇文章里小編給大家分享了關于python中判斷數(shù)字是否為質數(shù)的實例講解內容,有興趣的朋友們可以學習下。2020-12-12

