溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Django中AutoField字段的用法

發(fā)布時間:2020-07-23 16:34:30 來源:億速云 閱讀:275 作者:小豬 欄目:開發(fā)技術

這篇文章主要講解了Django中AutoField字段的用法,內容清晰明了,對此有興趣的小伙伴可以學習一下,相信大家閱讀完之后會有幫助。

【Django是一個機智的框架】

默認情況下Djang會為ORM中定義的每一張表加上一個自增ID列,并且用這個列來做主鍵;出于一個MySQL-DBA的工作經歷我覺得

Djanog還真是機智;這樣么說主要是因為我遇到過許多主從延時的問題,有些比較過分的會延時好幾周,通常這些都是因為binlog格式

為“ROW”但是表上不存在主鍵引起的。

如果當前網站用的是Django開發(fā)的,我想就不會有這種事情發(fā)生了吧。

【AutoField】

Django默認的行為就像這樣

class TestModel(models.Model):
 id = models.AutoField(primary_key=True)

數(shù)據庫層面對應的SQL如下

CREATE TABLE `myapp_testmodel` (
 `id` int(11) NOT NULL AUTO_INCREMENT,
 PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8

【注意】

如果你想的工增加AutoField列,但是又不指定這個列做為主鍵的話,是會報錯的

class TestModel(models.Model):
 tid = models.AutoField()

不顯示指定主鍵,但是又給表增加AutoField列的話就會報錯

assert not cls._meta.auto_field, "Model %s can't have more than one AutoField." % cls._meta.label
AssertionError: Model myapp.TestModel can't have more than one AutoField.

補充知識:Django中models下常用Field以及字段參數(shù)

一、常見的FieldType數(shù)據庫字段類型

1、AutoField:自增Field域,自動增加的一個數(shù)據庫字段類型,例如id字段就可以使用該數(shù)據類型,參數(shù)中必須填入primary_key=True

2、BigAutoField:和AutoField相同,只是比AutoField要大,參數(shù)中必須填入primary_key=True

3、BigIntegerField:大整型,只要用于存儲整型的數(shù)據

4、BinaryField:主要是存儲原始的二進制數(shù)據

5、BooleanField:主要是存儲布爾類型的數(shù)據,0和1

6、CharField:主要存儲字符串的數(shù)據類型

7、DateField:主要存儲日期類型的數(shù)據類型,日期格式為YYYY-MM-DD

8、DateTimeField:主要存儲時間相關的數(shù)據類型,格式為YYYY-MM-DD HH:MM:[ss[.uuuuuu]][TZ]

注意:DateField與DateTimeField有兩個屬性,配置auto_now_add=True,創(chuàng)建數(shù)據記錄的時候會把當前時間添加到數(shù)據庫,配置auto_now=True,每次更新數(shù)據記錄的時候都會更新該字段

9、DecimalField:主要存儲固定精度的十進制數(shù)據

--參數(shù):max_digits(小數(shù)總長度)/decimal_places(小數(shù)位長度)

10、EmailField:存儲電子郵件格式的數(shù)據,Django Admin以及ModelForm中提供驗證機制

11、FileField:存儲文件類型的數(shù)據,文件上傳到指定目錄

--參數(shù):upload_to="...."(上傳文件的保存路徑)/storage=None(存儲組件,默認django.core.files.storage.FileSystemStorage)

12、FilePathField:存儲文件路徑的數(shù)據,提供讀取文件夾下文件的功能

--參數(shù):path(文件夾路徑)/match=None(正則匹配)/recursive=False(遞歸下面的文件夾)/allow_files=True(允許文件)/allow_folders=False(允許文件夾)

13、FloatField:存儲浮點型數(shù)據

14、ImageField:存儲圖片型數(shù)據,文件上傳到指定目錄

--參數(shù):upload_to="....."(上傳文件的保存路徑)/storage=None(存儲組件,默認django.core.files.storage.FileSystemStorage)/width_field=None(上傳圖片的寬度保存的數(shù)據庫字段名<字符串>)/height_field=None(上傳圖片的高度保存的數(shù)據庫字段名<字符串>)

15、IntegerField:存儲整型數(shù)據

16、GenericIPAddressField:存儲IP地址信息數(shù)據

17、NullBooleanField:可以存儲布爾值數(shù)據,也可以存儲空null數(shù)據

18、PositiveIntegerField:主要存儲正整數(shù)數(shù)據

19、SmallIntegerField:小整型,主要用于存儲整型的數(shù)據

20、TextField:存儲文章內容信息數(shù)據,存儲比較長的文本信息

21、TimeField:存儲時間信息

22、URLField:存儲URL網址信息,Django Admin以及ModelForm中提供驗證url

23、IPAddressField:Django Admin以及ModelForm中提供驗證IPV4機制

24、GenericIPAddressField:Django Admin以及ModelForm中提供驗證IPV4和IPV6機制

二、常用關系型數(shù)據表處理Field

1、處理一對多關系數(shù)據表:使用ForeignKey

2、處理多對多關系數(shù)據表:使用ManyToManyField

三、字段參數(shù)

1、null:用于表示某個字段可以為空

2、unique:如果設置為unique=True則該字段在此表中必須是唯一的

3、db_index:如果db_index=True則代表這為此字段設置索引

4、default:為該字段設置默認值

四、關系字段

1、to:設置要關聯(lián)的表

2、to_field:設置要關聯(lián)的表的字段

3、related_name:反向操作時,使用的字段名,用于代替原反向查詢時的"表名_set"

4、on_delete:當刪除關聯(lián)表中的數(shù)據時,當前表與其關聯(lián)的行的行為,例如刪除一個出版社,那么和這個出版社有關聯(lián)的書籍也都被刪除掉了,下面介紹on_delete的參數(shù)值:

on_delete=models.CASCADE:刪除關聯(lián)數(shù)據,與之關聯(lián)也刪除

on_delete=models.DO_NOTHING:刪除關聯(lián)數(shù)據,引發(fā)錯誤IntegrityError

on_delete=models.PROTECT:刪除關聯(lián)數(shù)據,引發(fā)錯誤ProtectedError

on_delete=models.SET_NULL:刪除關聯(lián)數(shù)據,與之關聯(lián)的值設置為null(前提FK字段需要設置為可空)

on_delete=models.SET_DEFAULT:刪除關聯(lián)數(shù)據,與之關聯(lián)的值設置為默認值(前提FK字段需要設置默認值)

on_delete=models.SET:刪除關聯(lián)數(shù)據:

a、與之關聯(lián)的值設置為指定值,設置:models.SET(值)

b、與之關聯(lián)的值設置為可執(zhí)行對象的返回值,設置:models.SET(可執(zhí)行對象)

5、db_constraint:是否在數(shù)據庫中創(chuàng)建外鍵約束,默認為True,db_constraint一般使用在建立數(shù)據表連接關系當中(例如創(chuàng)建外鍵),如果使用False,則是限制了表之間沒有關聯(lián),達到了軟連接的效果

五、元信息

ORM對應的類里面包含另一個Meta類,而Meta類封裝了一些數(shù)據庫的信息,主要字段如下:

1、db_table:ORM在數(shù)據庫中的表名默認為app_類名,可以通過db_table可以重寫表名

2、index_together:聯(lián)合索引,給兩列做索引

3、unique_together:聯(lián)合唯一索引,兩列不能重復

4、ordering:指定默認按什么字段順序,只有設置了該屬性,我們查詢到的結果才可以被reverse()

看完上述內容,是不是對Django中AutoField字段的用法有進一步的了解,如果還想學習更多內容,歡迎關注億速云行業(yè)資訊頻道。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI