您好,登錄后才能下訂單哦!
小編這次要給大家分享的是如何重寫django的model下的objects模型管理器,文章內容豐富,感興趣的小伙伴可以來了解一下,希望大家閱讀完這篇文章之后能夠有所收獲。
django自定義管理器和model的繼承
在我寫代碼時建立的很多數據庫需要一些共同的字段,比如is_active, create_time這些字段,所以可以建立一個基類model
模型的繼承
我們可以充分利用oop特性,建立一個基類model,以后所有的model都繼承這個類, 就不用在每個類都額外添加字段
class BaseModel(models.Model): is_active = models.BooleanField(default=True) create_time = models.DateTimeField() class Meta: ''' 指定這個類是一個抽象模型類, 這個模型就不會被生成表 ''' abstract = True class ChildModel(BaseModel): name = models.CharField(max_length=10) age = models.PositiveIntegerField() class Meta: ''' meta屬性可以重寫, 不重寫的話也會繼承基類meta ''' verbose_name = '子模型'
重寫Django的model.objects
當我們使用model.objects.filter()時,經常會過濾掉is_active=False的,但是這樣我們每個 filter(is_active=True)都需要這樣寫,那我們能不能重寫掉這個filter方法, 讓他每次可以自己過濾掉,這里我們可以看一下django的源碼
# 這里源碼我就不拉出來了, 我們可以看到django是set了個objects屬性, 這個屬性對應是一個類的實例對象 class Manager(BaseManager.from_queryset(QuerySet)): ''' objects 是這個類的實例對象, 這個類我們可以看到他其實繼承了 QuerySet類里的方法, 所以我們可以直接重寫個這個類方法,并重寫filter方法 ''' def filter(self, *args, **kwargs): """ 我們可以看到 QuerySet里的filter方法和exclude方法都是調用了這個方法, 這個方法的內部實現可 以自己看一看,就是用的kwargs里的參數 """ return self._filter_or_exclude(False, *args, **kwargs) class MyManager(models.Manager): def filter(self, *args, **kwargs): ''' 源代碼的filter函數是有返回值的,所以我們將super出來的結果返回出去,我們只需要在kwargs中增加個參數就行 ''' if not kwargs.get('is_active', True): # 如果需要查看所有數據, kwargs['is_active'] = False return super(AddressManager, self).filter(*args, **kwargs) # 最后我們在我們的ChildModel下將objects對象賦值為MyManager的實例對象就可以使用了 # 我們可以將這個objects寫在基類里面,這樣所有的model就可以都會有這個方法,具體怎么使用視情況而定 class ChildModel(models.Model): objects = MyManager()
模型類也是可以多繼承的,如果有特殊的用法可以具體百度或Google一下, 這里只是個簡單的引入面向對象的概念,我們很多地方可以用繼承框架已有的類并重寫類中的方法,是我們的代碼更加pythonic
補充知識:Django中的Model中的字段屬性和選項
字段類型:
autoField:一個根據實際ID自動增長的IntegerField,通常不指定,如果不指定,一個主鍵字段將自動添加到模型中
CharField(max_length=字符長度):字符串,默認的表彰樣式是TextInput
TextField:大文本字段,一般超過4000時使用,默認的表單控件是Textarea
IntegerField:整數
DecimalField(max_digits=None, decimal_places=None): 使用Python的Decimal實例表示的十進制浮點數
參數說明: DecimalField.max_digits----位數總數
DecimalField.decimal_places---小數點后的數字位置
FloatField: 使用Python的float實例來表示的浮點數
BooleanField:True/False 字段,此字段的默認表彰控制是CheckboxInput
NullBooleanField:支持 Null, True, False 三種值
DateField([auto_now=False, auto_now_add=False]):使用Python的datetime.date實例表示的日期
參數說明:
DateField.auto_now
每次保存對象時,自動設置該字段為當前時間,用于“最后一次修改”
的時間戳,它總是使用當前日期,默認為 False
DateField.auto_now_add
當前對象第一次被創建時自動設置當前時間,用于創建的時間戳,
它總是使用當前日期,默認為 False
說明
該字段默認對應的表單控件是一個TextInput.在管理員站點添加了一個
JavaScript寫的日歷控件,和一個“Today”的快捷按鈕,包含了一個額外
的invalid_date錯誤消息鍵
注意
auto_now_add, auto_now, and default 這些設置是相互排斥的,他們之間
的任何組合將會發生錯誤的結果
TimeField: 使用Python的datetime.time實例表示的時間,參數同DateField
DateTimeField: 使用Python的datetime, datetime實例表示的日期和時間,參數同DateField
FileField: 一個上傳文件的字段
ImageField:繼承了FileField的所有屬性和方法,但對上傳的對象進行校驗,確保它是一個有效的image
字段選項
概述:通過字段選項,可以實現對字段的約束, 在字段對象中通過關鍵字參數指定
null:如果為True,Django將空值以NULL存儲在數據庫中,默認值為False
blanke:如果為True,則該字段允許為空白,默認值為False
注意: null是數據庫范疇的概念,blank是表彰驗證范疇的概念
db_column:字段的名稱,如果未指定,則使用屬性的名稱
db_index:若值為 True,則在表中會為此字段創建索引
default: 默認值
primary_key: 若為 True,則該字段會成為模型的主鍵字段
unique:如果為 True,這個字段在表中必須有唯一值
注意:在生成遷移文件之后如果修改的參數不影響表結構,則不用重新生成遷移文件。(default,blank 不影響表的結構。不用重新生成遷移文件)
關系類型
分類:
ForeignKey:一對多,將字段定義在多的端中
ManyToManyField:多對多,將字段定義在兩端中
OneToOneField:一對一,將字段定義在任意一端中
(1)用一訪問多:格式: 對象.模型類小寫_set
示例: grade.students_set
(2)用一訪問一:格式:對象.模型類小寫
示例: grade.studnets
(3)訪問id:格式:對象.屬性_id
例子:btitle = models.CharField(max_length=20,db_column=‘title',unique=‘true')
看完這篇關于如何重寫django的model下的objects模型管理器的文章,如果覺得文章內容寫得不錯的話,可以把它分享出去給更多人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。