<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        詳解Python的Django框架中Manager方法的使用

        來源:懂視網 責編:小采 時間:2020-11-27 14:34:32
        文檔

        詳解Python的Django框架中Manager方法的使用

        詳解Python的Django框架中Manager方法的使用:在語句Book.objects.all()中,objects是一個特殊的屬性,需要通過它查詢數據庫。 在第5章,我們只是簡要地說這是模塊的manager 。現在是時候深入了解managers是什么和如何使用了。 總之,模塊manager是一個對象,Django模塊通過它進行數據庫查詢。 每
        推薦度:
        導讀詳解Python的Django框架中Manager方法的使用:在語句Book.objects.all()中,objects是一個特殊的屬性,需要通過它查詢數據庫。 在第5章,我們只是簡要地說這是模塊的manager 。現在是時候深入了解managers是什么和如何使用了。 總之,模塊manager是一個對象,Django模塊通過它進行數據庫查詢。 每

        在語句Book.objects.all()中,objects是一個特殊的屬性,需要通過它查詢數據庫。 在第5章,我們只是簡要地說這是模塊的manager 。現在是時候深入了解managers是什么和如何使用了。

        總之,模塊manager是一個對象,Django模塊通過它進行數據庫查詢。 每個Django模塊至少有一個manager,你可以創建自定義manager以定制數據庫訪問。

        下面是你創建自定義manager的兩個原因: 增加額外的manager方法,和/或修manager返回的初始QuerySet。
        增加額外的Manager方法

        增加額外的manager方法是為模塊添加表級功能的首選辦法。

        例如,我們為Book模型定義了一個title_count()方法,它需要一個關鍵字,返回包含這個關鍵字的書的數量。 (這個例子有點牽強,不過它可以說明managers如何工作。)

        # models.py
        
        from django.db import models
        
        # ... Author and Publisher models here ...
        
        **class BookManager(models.Manager):**
         **def title_count(self, keyword):**
         **return self.filter(title__icontains=keyword).count()**
        
        class Book(models.Model):
         title = models.CharField(max_length=100)
         authors = models.ManyToManyField(Author)
         publisher = models.ForeignKey(Publisher)
         publication_date = models.DateField()
         num_pages = models.IntegerField(blank=True, null=True)
         **objects = BookManager()**
        
         def __unicode__(self):
         return self.title

        有了這個manager,我們現在可以這樣做:

        >>> Book.objects.title_count('django')
        4
        >>> Book.objects.title_count('python')
        18
        
        

        下面是編碼該注意的一些地方:

      1. 我們建立了一個BookManager類,它繼承了django.db.models.Manager。這個類只有一個title_count()方法,用來做統計。 注意,這個方法使用了self.filter(),此處self指manager本身。
      2. 我們把BookManager()賦值給模型的objects屬性。 它將取代模型的默認manager(objects)如果我們沒有特別定義,它將會被自動創建。 我們把它命名為objects,這是為了與自動創建的manager保持一致。
      3. 為什么我們要添加一個title_count()方法呢?是為了將經常使用的查詢進行封裝,這樣我們就不必重復編碼了。
        修改初始Manager QuerySets

        manager的基本QuerySet返回系統中的所有對象。 例如,`` Book.objects.all()`` 返回數據庫book中的所有書本。

        我們可以通過覆蓋Manager.get_query_set()方法來重寫manager的基本QuerySet。 get_query_set()按照你的要求返回一個QuerySet。

        例如,下面的模型有* 兩個* manager。一個返回所有對像,另一個只返回作者是Roald Dahl的書。

        from django.db import models
        
        **# First, define the Manager subclass.**
        **class DahlBookManager(models.Manager):**
         **def get_query_set(self):**
         **return super(DahlBookManager, self).get_query_set().filter(author='Roald Dahl')**
        
        **# Then hook it into the Book model explicitly.**
        class Book(models.Model):
         title = models.CharField(max_length=100)
         author = models.CharField(max_length=50)
         # ...
        
         **objects = models.Manager() # The default manager.**
         **dahl_objects = DahlBookManager() # The Dahl-specific manager.**
        
        

        在這個示例模型中,Book.objects.all()返回了數據庫中的所有書本,而Book.dahl_objects.all()只返回了一本. 注意我們明確地將objects設置成manager的實例,因為如果我們不這么做,那么唯一可用的manager就將是dah1_objects。

        當然,由于get_query_set()返回的是一個QuerySet對象,所以我們可以使用filter(),exclude()和其他一切QuerySet的方法。 像這些語法都是正確的:

        Book.dahl_objects.all()
        Book.dahl_objects.filter(title='Matilda')
        Book.dahl_objects.count()
        
        

        這個例子也指出了其他有趣的技術: 在同一個模型中使用多個manager。 只要你愿意,你可以為你的模型添加多個manager()實例。 這是一個為模型添加通用濾器的簡單方法。

        例如:

        class MaleManager(models.Manager):
         def get_query_set(self):
         return super(MaleManager, self).get_query_set().filter(sex='M')
        
        class FemaleManager(models.Manager):
         def get_query_set(self):
         return super(FemaleManager, self).get_query_set().filter(sex='F')
        
        class Person(models.Model):
         first_name = models.CharField(max_length=50)
         last_name = models.CharField(max_length=50)
         sex = models.CharField(max_length=1, choices=(('M', 'Male'), ('F', 'Female')))
         people = models.Manager()
         men = MaleManager()
         women = FemaleManager()
        
        

        這個例子允許你執行`` Person.men.all()`` ,`` Person.women.all()`` ,`` Person.people.all()`` 查詢,生成你想要的結果。

        如果你使用自定義的Manager對象,請注意,Django遇到的第一個Manager(以它在模型中被定義的位置為準)會有一個特殊狀態。 Django將會把第一個Manager 定義為默認Manager ,Django的許多部分(但是不包括admin應用)將會明確地為模型使用這個manager。 結論是,你應該小心地選擇你的默認manager。因為覆蓋get_query_set() 了,你可能接受到一個無用的返回對像,你必須避免這種情況。

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        詳解Python的Django框架中Manager方法的使用

        詳解Python的Django框架中Manager方法的使用:在語句Book.objects.all()中,objects是一個特殊的屬性,需要通過它查詢數據庫。 在第5章,我們只是簡要地說這是模塊的manager 。現在是時候深入了解managers是什么和如何使用了。 總之,模塊manager是一個對象,Django模塊通過它進行數據庫查詢。 每
        推薦度:
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 亚洲成A∨人片在线观看无码| 亚洲欭美日韩颜射在线二| 亚洲男女一区二区三区| 无码国产精品一区二区免费式芒果| 亚洲中文字幕第一页在线| 中国黄色免费网站| 国产成人精品日本亚洲| 国偷自产一区二区免费视频| 亚洲AV无码专区国产乱码4SE| 99视频免费在线观看| 亚洲视频在线观看| 18勿入网站免费永久| 亚洲一区二区三区国产精品无码| 97性无码区免费| 免费观看亚洲人成网站| 亚洲国产精品专区在线观看| 成人无码精品1区2区3区免费看| 国产亚洲精品无码拍拍拍色欲| 99久久成人国产精品免费 | 亚洲欧洲另类春色校园网站| 91麻豆最新在线人成免费观看| 亚洲一级特黄特黄的大片| 日本午夜免费福利视频| 免费无码专区毛片高潮喷水| 国产成人A亚洲精V品无码| 一级毛片免费不卡在线| 中文字幕在线观看亚洲视频| 国产一区二区三区免费视频| 国色精品va在线观看免费视频| 亚洲韩国在线一卡二卡| 男人的好看免费观看在线视频| 色www免费视频| 亚洲另类激情综合偷自拍图| 国拍在线精品视频免费观看| 色偷偷尼玛图亚洲综合| 亚洲Av无码专区国产乱码DVD| 欧洲精品成人免费视频在线观看 | 中文文字幕文字幕亚洲色| 国产18禁黄网站免费观看| 少妇性饥渴无码A区免费| 亚洲中文字幕一二三四区|