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
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...