Django基礎之Model操作

来源:http://www.cnblogs.com/qianyuliang/archive/2017/05/27/6910961.html
-Advertisement-
Play Games

一、資料庫操作 1、創建model表 基本結構: 欄位解釋: 1 1、models.AutoField 自增列= int(11) 2 如果沒有的話,預設會生成一個名稱為 id 的列,如果要顯示的自定義一個自增列,必須將給列設置為主鍵 primary_key=True。 3 2、models.Char ...


一、資料庫操作

1、創建model表

基本結構:

1 #coding:Utf8
2 from django.db import models
3    
4 class userinfo(models.Model):
5     #如果沒有models.AutoField,預設會創建一個id的自增列
6     name = models.CharField(max_length=30)
7     email = models.EmailField()
8     memo = models.TextField()

欄位解釋:

 1 1、models.AutoField  自增列= int(11)
 2   如果沒有的話,預設會生成一個名稱為 id 的列,如果要顯示的自定義一個自增列,必須將給列設置為主鍵 primary_key=True。
 3 2、models.CharField  字元串欄位
 4   必須 max_length 參數
 5 3、models.BooleanField  布爾類型=tinyint(1)
 6   不能為空,Blank=True
 7 4、models.ComaSeparatedIntegerField  用逗號分割的數字=varchar
 8   繼承CharField,所以必須 max_lenght 參數
 9 5、models.DateField  日期類型 date
10   對於參數,auto_now =True則每次更新都會更新這個時間;auto_now_add 則只是第一次創建添加,之後的更新不再改變。
11 6、models.DateTimeField  日期類型 datetime
12   同DateField的參數
13 7、models.Decimal  十進位小數類型= decimal
14   必須指定整數位max_digits和小數位decimal_places
15 8、models.EmailField  字元串類型(正則表達式郵箱)=varchar
16   對字元串進行正則表達式
17 9、models.FloatField  浮點類型= double
18 10、models.IntegerField  整形
19 11、models.BigIntegerField  長整形
20   integer_field_ranges ={
21     'SmallIntegerField':(-32768,32767),
22     'IntegerField':(-2147483648,2147483647),
23     'BigIntegerField':(-9223372036854775808,9223372036854775807),
24     'PositiveSmallIntegerField':(0,32767),
25     'PositiveIntegerField':(0,2147483647),
26   }
27 12、models.IPAddressField  字元串類型(ip4正則表達式)
28 13、models.GenericIPAddressField  字元串類型(ip4和ip6是可選的)
29   參數protocol可以是:both、ipv4、ipv6
30   驗證時,會根據設置報錯
31 14、models.NullBooleanField  允許為空的布爾類型
32 15、models.PositiveIntegerFiel  正Integer
33 16、models.PositiveSmallIntegerField  正smallInteger
34 17、models.SlugField  減號、下劃線、字母、數字
35 18、models.SmallIntegerField  數字
36   資料庫中的欄位有:tinyint、smallint、int、bigint
37 19、models.TextField  字元串=longtext
38 20、models.TimeField  時間 HH:MM[:ss[.uuuuuu]]
39 21、models.URLField  字元串,地址正則表達式
40 22、models.BinaryField  二進位
41 23、models.ImageField圖片
42 24、models.FilePathField文件
更多欄位

參數解釋:

 1 1、null=True
 2   資料庫中欄位是否可以為空
 3 2、blank=True
 4   django的Admin中添加數據時是否可允許空值
 5 3、primary_key =False
 6   主鍵,對AutoField設置主鍵後,就會代替原來的自增 id 列
 7 4、auto_now 和 auto_now_add
 8   auto_now 自動創建---無論添加或修改,都是當前操作的時間
 9   auto_now_add 自動創建---永遠是創建時的時間
10 5、choices
11 GENDER_CHOICE =(
12 (u'M', u'Male'),
13 (u'F', u'Female'),
14 )
15 gender = models.CharField(max_length=2,choices = GENDER_CHOICE)
16 6、max_length
17 7、default  預設值
18 8、verbose_name  Admin中欄位的顯示名稱
19 9、name|db_column  資料庫中的欄位名稱
20 10、unique=True  不允許重覆
21 11、db_index =True  資料庫索引
22 12、editable=True  在Admin里是否可編輯
23 13、error_messages=None  錯誤提示
24 14、auto_created=False  自動創建
25 15、help_text  在Admin中提示幫助信息
26 16、validators=[]
27 17、upload-to
參數解釋

 

進行數據的操作

查:

 

models.UserInfo.objects.all()

 

models.UserInfo.objects.all().values('user')    #只取user列

 

models.UserInfo.objects.all().values_list('id','user')    #取出id和user列,並生成一個列表

 

models.UserInfo.objects.get(id=1)  #取id=1的數據

 

models.UserInfo.objects.get(user='rose')  #取user=‘rose’的數據  

增:

models.UserInfo.objects.create(user='rose',pwd='123456')
或者 obj = models.UserInfo(user='rose',pwd='123456') obj.save() 或者 dic = {'user':'rose','pwd':'123456'} models.UserInfo.objects.create(**dic)
 

刪:

models.UserInfo.objects.filter(user='rose').delete()  

改: 

models.UserInfo.objects.filter(user='rose').update(pwd='520') 或者 obj = models.UserInfo.objects.get(user='rose') obj.pwd = '520' obj.save()   例舉常用方法:
 1 # 獲取個數
 2     #
 3     # models.Tb1.objects.filter(name='seven').count()
 4     # 大於,小於
 5     #
 6     # models.Tb1.objects.filter(id__gt=1)              # 獲取id大於1的值
 7     # models.Tb1.objects.filter(id__lt=10)             # 獲取id小於10的值
 8     # models.Tb1.objects.filter(id__lt=10, id__gt=1)   # 獲取id大於1 且 小於10的值
 9     # in
10     #
11     # models.Tb1.objects.filter(id__in=[11, 22, 33])   # 獲取id等於11、22、33的數據
12     # models.Tb1.objects.exclude(id__in=[11, 22, 33])  # not in
13     # contains
14     #
15     # models.Tb1.objects.filter(name__contains="ven")
16     # models.Tb1.objects.filter(name__icontains="ven") # icontains大小寫不敏感
17     # models.Tb1.objects.exclude(name__icontains="ven")
18     # range
19     #
20     # models.Tb1.objects.filter(id__range=[1, 2])   # 範圍bettwen and
21     # 其他類似
22     #
23     # startswith,istartswith, endswith, iendswith,
24     # order by
25     #
26     # models.Tb1.objects.filter(name='seven').order_by('id')    # asc
27     # models.Tb1.objects.filter(name='seven').order_by('-id')   # desc
28     # limit 、offset
29     #
30     # models.Tb1.objects.all()[10:20]
31     # group by
32     from django.db.models import Count, Min, Max, Sum
33     # models.Tb1.objects.filter(c1=1).values('id').annotate(c=Count('num'))
34     # SELECT "app01_tb1"."id", COUNT("app01_tb1"."num") AS "c" FROM "app01_tb1" WHERE "app01_tb1"."c1" = 1 GROUP BY "app01_tb1"."id"
常用方法  

二、詳解常用欄位

models.DateTimeField  日期類型 datetime 參數, auto_now = True :則每次更新都會更新這個時間 auto_now_add 則只是第一次創建添加,之後的更新不再改變。
1 class UserInfo(models.Model):
2     name = models.CharField(max_length=32)
3     ctime = models.DateTimeField(auto_now=True)
4     uptime = models.DateTimeField(auto_now_add=True)
1 from app01 import models
2 def home(request):
3     models.UserInfo.objects.create(name='yangmv')
4     after = models.UserInfo.objects.all()
5     print after[0].ctime
6     return render(request, 'app01/home.html')
 

表結構的修改

表結構修改後,原來表中已存在的數據,就會出現結構混亂,makemigrations更新表的時候就會出錯 解決方法: 1、新增加的欄位,設置允許為空。生成表的時候,之前數據新增加的欄位就會為空。(null=True允許資料庫中為空,blank=True允許admin後臺中為空) 2、新增加的欄位,設置一個預設值。生成表的時候,之前的數據新增加欄位就會應用這個預設值
1 from django.db import models
2 
3 # Create your models here.
4 class UserInfo(models.Model):
5      name = models.CharField(max_length=32)
6      ctime = models.DateTimeField(auto_now=True)
7      uptime = models.DateTimeField(auto_now_add=True)
8      email = models.EmailField(max_length=32,null=True)
9      email1 = models.EmailField(max_length=32,default='[email protected]')

執行makemigrations, migrate 後。老數據會自動應用新增加的規則

 

models.ImageField                        圖片

models.GenericIPAddressField      IP

ip = models.GenericIPAddressField(protocol="ipv4",null=True,blank=True)
img = models.ImageField(null=True,blank=True,upload_to="upload")
 

常用參數

選擇下拉框 choices
1 class UserInfo(models.Model):
2     USER_TYPE_LIST = (
3         (1,'user'),
4 (2,'admin'),
5 )
6     user_type = models.IntegerField(choices=USER_TYPE_LIST,default=1)

 

2、連表結構

  • 一對多:models.ForeignKey(其他表)
  • 多對多:models.ManyToManyField(其他表)
  • 一對一:models.OneToOneField(其他表)
 

應用場景:

  • 一對多:當一張表中創建一行數據時,有一個單選的下拉框(可以被重覆選擇)
    例如:創建用戶信息時候,需要選擇一個用戶類型【普通用戶】【金牌用戶】【鉑金用戶】等。
  • 多對多:在某表中創建一行數據是,有一個可以多選的下拉框
    例如:創建用戶信息,需要為用戶指定多個愛好
  • 一對一:在某表中創建一行數據時,有一個單選的下拉框(下拉框中的內容被用過一次就消失了
    例如:原有含10列數據的一張表保存相關信息,經過一段時間之後,10列無法滿足需求,需要為原來的表再添加5列數據

一對多:

 1 from django.db import models
 2 
 3 
 4 # Create your models here.
 5 class UserType(models.Model):
 6     name = models.CharField(max_length=50)    
 7 class UserInfo(models.Model):
 8     username = models.CharField(max_length=50)
 9     password = models.CharField(max_length=50)
10     email = models.EmailField()
11     user_type = models.ForeignKey('UserType')  

 這是UserInfo表,可以通過外鍵,對應到UserType表的ID

 

這是User_Type表的數據

 

多對多:

 1 from django.db import models
 2 
 3 
 4 # Create your models here.
 5 class UserType(models.Model):
 6     name = models.CharField(max_length=50)    
 7 class UserInfo(models.Model):
 8     username = models.CharField(max_length=50)
 9     password = models.CharField(max_length=50)
10     email = models.EmailField()
11     user_type = models.ForeignKey('UserType')    
12 class UserGroup(models.Model):
13     GroupName = models.CharField(max_length=50)
14     user = models.ManyToManyField("UserInfo")

Django model會自動創建第3張關係表,用於對應UserInfo_id 和UserGroup_id

UserInfo表如上所示:

UserGroup表

Django自動生成的對應關係表

userinfo_id = 1 為 Boss,屬於1(用戶組A)

 

一對一:   (一對多增加了不能重覆)

 1 from django.db import models
 2 
 3 
 4 # Create your models here.
 5 class UserType(models.Model):
 6     name = models.CharField(max_length=50)    
 7 class UserInfo(models.Model):
 8     username = models.CharField(max_length=50)
 9     password = models.CharField(max_length=50)
10     email = models.EmailField()
11     user_type = models.ForeignKey('UserType')    
12 class UserGroup(models.Model):
13     GroupName = models.CharField(max_length=50)
14     user = models.ManyToManyField("UserInfo")    
15 class Admin(models.Model):
16     Address = models.CharField()
17     user_info_address = models.OneToOneField('UserInfo')

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • gdisk用法 gdisk - InteractiveGUIDpartitiontable (GPT) manipulator GPTfdisk (akagdisk) isatext-modemenu-drivenprogramforcreationandmanipulation ofpartiti ...
  • 思考了一下AOP的具體實現,後來想到ASP.NET MVC過濾器其實就是AOP的一種,於是從Filter下手研究AOP. 暫時先考慮AuthorizationFilter,ActionFilter,ResultFilter三種,剩下的兩種其實也差不多。AuthorizationFilter的實現最好 ...
  • 函數 1. 函數名是標識符之一,只能有字母數字下劃線,開頭不能是數字; 函數名的命名,必須符合“小駝峰法則”FUNC(),func(),Func(); 函數名不區分大小寫; 函數名不能與已有函數同名,不能與內置函數名同名; 2. function_exists("func");用於檢測函數是否已經聲 ...
  • 服務端 ...
  • 正則(regular),要使用正則表達式需要導入Python中的re(regular正則的縮寫)模塊。正則表達式是對字元串的處理,我們知道,字元串中有時候包含很多我們想要提取的信息,掌握這些處理字元串的方法,能夠方便很多我們的操作。 正則表達式(regular),處理字元串的方法。http://ww ...
  • Java動態編譯 一、動態編譯簡介 new創建對象是靜態載入類,在編譯時刻就需要載入所有可能使用到的類。 一百個類,有一個類錯了,都無法編譯。 通過動態載入類可以解決該問題 二、代碼實例 2.1 OfficeBetter.java main介面 裡面通過對Class類的動態編譯 然後調用實例,完成動 ...
  • Class類 一、簡介 class本身是一個類 二、表示形式 class c1 = Foo.class; class c2 = fool1.getClass(); class c3 = Class.forName("com.imooc.reflect.Foo");//動態載入 ...
  • Python 與 mysql 數據連接 用pymysql 基本操作大概就這樣這次爬取的是淘寶商品頁面 過程就略了放代碼 可以看到所需要的數據已經存入資料庫了 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...