1. django 模型models 經常使用字段git
一、models.AutoField
- 自增列 = int(11)
- 若是沒有的話,默認會生成一個名稱爲 id 的列
- 若是要顯式的自定義一個自增列,必須設置primary_key=True。
二、models.CharField
- 字符串字段
- 必須設置max_length參數
三、models.BooleanField
- 布爾類型=tinyint(1)
- 不能爲空,可添加Blank=True
四、models.ComaSeparatedIntegerField
- 用逗號分割的數字=varchar
- 繼承CharField,因此必須 max_lenght 參數
五、models.DateField
- 日期類型 date
- DateField.auto_now:保存時自動設置該字段爲如今日期,最後修改日期
- DateField.auto_now_add:當該對象第一次被建立是自動設置該字段爲如今日期,建立日期。
六、models.DateTimeField
- 日期時間類型 datetime
- 同DateField的參數
七、models.Decimal
- 十進制小數類型 = decimal
- DecimalField.max_digits:數字中容許的最大位數
- DecimalField.decimal_places:存儲的十進制位數
八、models.EmailField
- 一個帶有檢查 Email 合法性的 CharField
九、models.FloatField
- 浮點類型 = double
十、models.IntegerField
- 整形
十一、models.BigIntegerField
- 長整形
- integer_field_ranges = {
'SmallIntegerField': (-32768, 32767),'IntegerField': (-2147483648, 2147483647),'BigIntegerField': (-9223372036854775808, 9223372036854775807),'PositiveSmallIntegerField': (0, 32767),'PositiveIntegerField': (0, 2147483647),}
十二、models.GenericIPAddressField
- 一個帶有檢查 IP地址合法性的 CharField
1三、models.NullBooleanField
- 容許爲空的布爾類型
1四、models.PositiveIntegerFiel
- 正整數
1五、models.PositiveSmallIntegerField
- 正smallInteger
1六、models.SlugField
- 減號、下劃線、字母、數字
1七、models.SmallIntegerField
- 數字
- 數據庫中的字段有:tinyint、smallint、int、bigint
1八、models.TextField
- 大文本。默認對應的form標籤是textarea。
1九、models.TimeField
- 時間 HH:MM[:ss[.uuuuuu]]
20、models.URLField
- 一個帶有URL合法性校驗的CharField。
2一、models.BinaryField
- 二進制
- 存儲二進制數據。不能使用filter函數得到QuerySet。
2二、models.ImageField
- 圖片
- ImageField.height_field、ImageField.width_field:若是提供這兩個參數,則圖片將按提供的高度和寬度規格保存。
- 該字段要求 Python Imaging 庫Pillow。
- 會檢查上傳的對象是不是一個合法圖片。
2三、models.FileField(upload_to=None[, max_length=100, ** options])
- 文件
- FileField.upload_to:一個用於保存上傳文件的本地文件系統路徑,該路徑由 MEDIA_ROOT 中設置
- 這個字段不能設置primary_key和unique選項.在數據庫中存儲類型是varchar,默認最大長度爲100
2四、models.FilePathField(path=None[, math=None, recursive=False, max_length=100, **options])將匹配「/home/images/foo.gif」但不匹配「/home/images/foo/bar.gif」
- FilePathField.path:文件的絕對路徑,必填
- FilePathField.match:用於過濾路徑下文件名的正則表達式,該表達式將用在文件名上(不包括路徑)。
- FilePathField.recursive:True 或 False,默認爲 False,指定是否應包括全部子目錄的路徑。
- 例如:FilePathField(path="/home/images", match="foo.*", recursive=True)
一、null
- 若是是True,Django會在數據庫中將此字段的值置爲NULL,默認值是False
二、blank
- 若是爲True時django的 Admin 中添加數據時可容許空值,能夠不填。若是爲False則必須填。默認是False。
- null純粹是與數據庫有關係的。而blank是與頁面必填項驗證有關的
三、primary_key = False
- 主鍵,對AutoField設置主鍵後,就會代替原來的自增 id 列
四、auto_now 和 auto_now_add
- auto_now 自動建立---不管添加或修改,都是當前操做的時間
- auto_now_add 自動建立---永遠是建立時的時間
五、choices
- 一個二維的元組被用做choices,若是這樣定義,Django會select box代替普通的文本框,
- 而且限定choices的值是元組中的值
- GENDER_CHOICE = (
- (u'M', u'Male'),
- (u'F', u'Female'),
- )
- gender = models.CharField(max_length=2,choices = GENDER_CHOICE)
六、max_length
- 字段長度
七、default
- 默認值
八、verbose_name
- Admin中字段的顯示名稱,若是不設置該參數時,則與屬性名。
九、db_column
- 數據庫中的字段名稱
十、unique=True
- 不容許重複
十一、db_index = True
- 數據庫索引
十二、editable=True
- 在Admin裏是否可編輯
1三、error_messages=None
- 錯誤提示
1四、auto_created=False
- 自動建立
1五、help_text
- 在Admin中提示幫助信息
1六、validators=[]
- 驗證器
1七、upload-to
- 文件上傳時的保存上傳文件的目錄
02-class Meta:正則表達式
Django模型類的Meta是一個內部類,它用於定義一些Django模型類的行爲特性。而可用的選項大體包含如下幾類數據庫
這個屬性是定義當前的模型是否是一個抽象類。所謂抽象類是不會對應數據庫表的。通常咱們用它來概括一些公共屬性字段,而後繼承它的子類能夠繼承這些字段。django
Options.abstract
若是abstract = True 這個model就是一個抽象類app
這個選型只在一種狀況下使用,就是你的模型不在默認的應用程序包下的models.py文件中,這時候須要指定你這個模型是哪一個應用程序的。函數
Options.app_label
若是一個model定義在默認的models.py,例如若是你的app的models在myapp.models子模塊下,你必須定義app_label讓Django知道它屬於哪個app
app_label = 'myapp'spa
db_table是指定自定義數據庫代表的。Django有一套默認的按照必定規則生成數據模型對應的數據庫代表。
Options.db_table
定義該model在數據庫中的表名稱
db_table = 'Students'
若是你想使用自定義的表名,能夠經過如下該屬性
table_name = 'my_owner_table'代理
Options.db_teblespace
定義這個model所使用的數據庫表空間。若是在項目的settin中定義那麼它會使用這個值code
Options.get_latest_by
在model中指定一個DateField或者DateTimeField。這個設置讓你在使用model的Manager上的lastest方法時,默認使用指定字段來排序orm
Options.managed
默認值爲True,這意味着Django可使用syncdb和reset命令來建立或移除對應的數據庫。默認值爲True,若是你不但願這麼作,能夠把manage的值設置爲False
這個選項通常用於多對多的關係中,它指向一個關聯對象,就是說關聯對象找到這個對象後它是通過排序的。指定這個屬性後你會獲得一個get_xxx_order()和set_xxx_order()的方法,經過它們你能夠設置或者回去排序的對象
這個字段是告訴Django模型對象返回的記錄結果集是按照哪一個字段排序的。這是一個字符串的元組或列表,沒有一個字符串都是一個字段和用一個可選的代表降序的'-'構成。當字段名前面沒有'-'時,將默認使用升序排列。使用'?'將會隨機排列
permissions主要是爲了在Django Admin管理模塊下使用的,若是你設置了這個屬性可讓指定的方法權限描述更清晰可讀。Django自動爲每一個設置了admin的對象建立添加,刪除和修改的權限。
permissions = (('can_deliver_pizzas','Can deliver pizzas'))
這是爲了實現代理模型使用的,若是proxy = True,表示model是其父的代理 model
unique_together這個選項用於:當你須要經過兩個字段保持惟一性時使用。好比假設你但願,一個Person的FirstName和LastName二者的組合必須是惟一的,那麼須要這樣設置:
unique_together = (("first_name", "last_name"),)
一個ManyToManyField不能包含在unique_together中。若是你須要驗證關聯到ManyToManyField字段的惟一驗證,嘗試使用signal(信號)或者明確指定through屬性。
verbose_name的意思很簡單,就是給你的模型類起一個更可讀的名字通常定義爲中文,咱們:
verbose_name = "學校"
這個選項是指定,模型的複數形式是什麼,好比:
verbose_name_plural = "學校"
若是不指定Django會自動在模型名稱後加一個’s’
class Meta: db_table = "tb_users" # 指明數據庫表名 verbose_name = "用戶" # 在admin站點中顯示的名稱 verbose_name_plural = verbose_name # 顯示的複數名稱