Model
Django中的model是用來操作數據庫的,Model是一個ORM框架,我們只需要關心model的操作,而不需要關心到底是哪一種數據庫。
一、基本知識:
數據庫引擎:
Django中自帶的數據庫為sqlite,如果需要修改數據庫引擎,可以再settings.py中修改:
1 DATABASES = { 2 'default': { 3 'ENGINE': 'django.db.backends.sqlite3', 4 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'), 5 } 6 }
使用方法:
我們只需要在models.py文件中寫入代碼即可:
表結構對照圖:
ORM框架中,類class表示數據庫的表
根據類創建的對象,代表數據庫表中的一行數據。
對象.id 對象.value 代表行里面的數據
二、model里的字段
1、models.AutoField 自增列 = int(11) 如果沒有的話,默認會生成一個名稱為 id 的列,如果要顯示的自定義一個自增列,必須將給列設置為主鍵 primary_key=True。 2、models.CharField 字符串字段 必須 max_length 參數 3、models.BooleanField 布爾類型=tinyint(1) 不能為空,Blank=True 4、models.ComaSeparatedIntegerField 用逗號分割的數字=varchar 繼承CharField,所以必須 max_lenght 參數 5、models.DateField 日期類型 date 對於參數,auto_now = True 則每次更新都會更新這個時間;auto_now_add 則只是第一次創建添加,之后的更新不再改變。 6、models.DateTimeField 日期類型 datetime 同DateField的參數 7、models.Decimal 十進制小數類型 = decimal 必須指定整數位max_digits和小數位decimal_places 8、models.EmailField 字符串類型(正則表達式郵箱) =varchar 對字符串進行正則表達式 9、models.FloatField 浮點類型 = double 10、models.IntegerField 整形 11、models.BigIntegerField 長整形 integer_field_ranges = { 'SmallIntegerField': (-32768, 32767), 'IntegerField': (-2147483648, 2147483647), 'BigIntegerField': (-9223372036854775808, 9223372036854775807), 'PositiveSmallIntegerField': (0, 32767), 'PositiveIntegerField': (0, 2147483647), } 12、models.IPAddressField 字符串類型(ip4正則表達式) 13、models.GenericIPAddressField 字符串類型(ip4和ip6是可選的) 參數protocol可以是:both、ipv4、ipv6 驗證時,會根據設置報錯 14、models.NullBooleanField 允許為空的布爾類型 15、models.PositiveIntegerFiel 正Integer 16、models.PositiveSmallIntegerField 正smallInteger 17、models.SlugField 減號、下划線、字母、數字 18、models.SmallIntegerField 數字 數據庫中的字段有:tinyint、smallint、int、bigint 19、models.TextField 字符串=longtext 20、models.TimeField 時間 HH:MM[:ss[.uuuuuu]] 21、models.URLField 字符串,地址正則表達式 22、models.BinaryField 二進制 23、models.ImageField 圖片 在數據庫中保存的是文件的路徑 24、models.FilePathField 文件
三、字段中的參數
1、null=True 數據庫中字段是否可以為空 2、blank=True django的 Admin 中添加數據時是否可允許空值 3、primary_key = False 主鍵,對AutoField設置主鍵后,就會代替原來的自增 id 列 4、auto_now 和 auto_now_add auto_now 自動創建---無論添加或修改,都是當前操作的時間 auto_now_add 自動創建---永遠是創建時的時間 5、choices GENDER_CHOICE = ( (u'M', u'Male'), (u'F', u'Female'), ) gender = models.CharField(max_length=2,choices = GENDER_CHOICE) 6、max_length 7、default 默認值 8、verbose_name Admin中字段的顯示名稱 9、name|db_column 數據庫中的字段名稱 10、unique=True 不允許重復 11、db_index = True 數據庫索引 12、editable=True 在Admin里是否可編輯 13、error_messages=None 錯誤提示 14、auto_created=False 自動創建 15、help_text 在Admin中提示幫助信息 16、validators=[] 17、upload-to 上傳路徑
四、上傳文件
根據上傳文件的契機,來寫一個簡單的上傳文件的例子
html文件

1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4 <meta charset="UTF-8"> 5 <title></title> 6 </head> 7 <body> 8 9 <form action="/upload/" method="POST" enctype="multipart/form-data"> 10 11 <p><input type="file" name="f1"></p> 12 <p><input type="file" name="f2"></p> 13 <p><input type="text" name="hostname"></p> 14 <input type="submit" value="上傳"> 15 16 </form> 17 18 </body> 19 </html>
views.py
1 def upload(request): 2
3 if request.method == "POST": 4 inp_file = request.FILES # 上傳的文件會在request.FILES里
5 file_obj1 = inp_file.get('f1') # 根據前端設置的name屬性值獲取相對應的文件
6
7 print inp_file 8 print file_obj1.name # 獲取文件名
9 print file_obj1.size 10 f = open(file_obj1.name, 'wb') # 以獲取的文件名 按‘wb’的方式打開一個文件
11 for line in file_obj1.chunks(): # chunks方法讀取文件,默認每次讀取64kb
12 f.write(line) 13 f.close() 14 return render(request, 'home/upload.html')