- 在模型中定義屬性,會(huì)生成表中的字段
- django根據(jù)屬性的類型確定以下信息:
- 當(dāng)前選擇的數(shù)據(jù)庫支持字段的類型
- 渲染管理表單時(shí)使用的默認(rèn)html控件
- 在管理站點(diǎn)最低限度的驗(yàn)證
- django會(huì)為表增加自動(dòng)增長(zhǎng)的主鍵列,每個(gè)模型只能有一個(gè)主鍵列,如果使用選項(xiàng)設(shè)置某屬性為主鍵列后,則django不會(huì)再生成默認(rèn)的主鍵列
- 屬性命名限制
- 不能是python的保留關(guān)鍵字
- 由于django的查詢方式,不允許使用連續(xù)的下劃線
定義屬性
字段類型
- AutoField:一個(gè)根據(jù)實(shí)際ID自動(dòng)增長(zhǎng)的IntegerField,通常不指定
- 如果不指定,一個(gè)主鍵字段將自動(dòng)添加到模型中
- BooleanField:true/false 字段,此字段的默認(rèn)表單控制是CheckboxInput
- NullBooleanField:支持null、true、false三種值
- CharField(max_length=字符長(zhǎng)度):字符串,默認(rèn)的表單樣式是 TextInput
- TextField:大文本字段,一般超過4000使用,默認(rèn)的表單控件是Textarea
- IntegerField:整數(shù)
- DecimalField(max_digits=None, decimal_places=None):使用python的Decimal實(shí)例表示的十進(jìn)制浮點(diǎn)數(shù)
- DecimalField.max_digits:位數(shù)總數(shù)
- DecimalField.decimal_places:小數(shù)點(diǎn)后的數(shù)字位數(shù)
- FloatField:用Python的float實(shí)例來表示的浮點(diǎn)數(shù)
- DateField[auto_now=False, auto_now_add=False]):使用Python的datetime.date實(shí)例表示的日期
- 參數(shù)DateField.auto_now:每次保存對(duì)象時(shí),自動(dòng)設(shè)置該字段為當(dāng)前時(shí)間,用于"最后一次修改"的時(shí)間戳,它總是使用當(dāng)前日期,默認(rèn)為false
- 參數(shù)DateField.auto_now_add:當(dāng)對(duì)象第一次被創(chuàng)建時(shí)自動(dòng)設(shè)置當(dāng)前時(shí)間,用于創(chuàng)建的時(shí)間戳,它總是使用當(dāng)前日期,默認(rèn)為false
- 該字段默認(rèn)對(duì)應(yīng)的表單控件是一個(gè)TextInput. 在管理員站點(diǎn)添加了一個(gè)JavaScript寫的日歷控件,和一個(gè)“Today"的快捷按鈕,包含了一個(gè)額外的invalid_date錯(cuò)誤消息鍵
- auto_now_add, auto_now, and default 這些設(shè)置是相互排斥的,他們之間的任何組合將會(huì)發(fā)生錯(cuò)誤的結(jié)果
- TimeField:使用Python的datetime.time實(shí)例表示的時(shí)間,參數(shù)同DateField
- DateTimeField:使用Python的datetime.datetime實(shí)例表示的日期和時(shí)間,參數(shù)同DateField
- FileField:一個(gè)上傳文件的字段
- ImageField:繼承了FileField的所有屬性和方法,但對(duì)上傳的對(duì)象進(jìn)行校驗(yàn),確保它是個(gè)有效的image
字段選項(xiàng)
- 通過字段選項(xiàng),可以實(shí)現(xiàn)對(duì)字段的約束
- 在字段對(duì)象時(shí)通過關(guān)鍵字參數(shù)指定
- null:如果為True,Django 將空值以NULL 存儲(chǔ)到數(shù)據(jù)庫中,默認(rèn)值是 False
- blank:如果為True,則該字段允許為空白,默認(rèn)值是 False
- 對(duì)比:null是數(shù)據(jù)庫范疇的概念,blank是表單驗(yàn)證證范疇的
- db_column:字段的名稱,如果未指定,則使用屬性的名稱
- db_index:若值為 True, 則在表中會(huì)為此字段創(chuàng)建索引
- default:默認(rèn)值
- primary_key:若為 True, 則該字段會(huì)成為模型的主鍵字段
- unique:如果為 True, 這個(gè)字段在表中必須有唯一值
關(guān)系
- 關(guān)系的類型包括
- ForeignKey:一對(duì)多,將字段定義在多的端中
- ManyToManyField:多對(duì)多,將字段定義在兩端中
- OneToOneField:一對(duì)一,將字段定義在任意一端中
- 可以維護(hù)遞歸的關(guān)聯(lián)關(guān)系,使用'self'指定,詳見“自關(guān)聯(lián)”
- 用一訪問多:對(duì)象.模型類小寫_set
bookinfo.heroinfo_set
heroinfo.bookinfo
heroinfo.book_id
元選項(xiàng)
- 在模型類中定義類Meta,用于設(shè)置元信息
- 元信息db_table:定義數(shù)據(jù)表名稱,推薦使用小寫字母,數(shù)據(jù)表的默認(rèn)名稱
<app_name>_<model_name>
- ordering:對(duì)象的默認(rèn)排序字段,獲取對(duì)象的列表時(shí)使用,接收屬性構(gòu)成的列表
class BookInfo(models.Model):
...
class Meta():
ordering = ['id']
class BookInfo(models.Model):
...
class Meta():
ordering = ['-id']
- 排序會(huì)增加數(shù)據(jù)庫的開銷
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。