怎么在Django中利用Model操作表?相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。
創新互聯公司是創新、創意、研發型一體的綜合型網站建設公司,自成立以來公司不斷探索創新,始終堅持為客戶提供滿意周到的服務,在本地打下了良好的口碑,在過去的十載時間我們累計服務了上千家以及全國政企客戶,如人造霧等企業單位,完善的項目管理流程,嚴格把控項目進度與質量監控加上過硬的技術實力獲得客戶的一致贊譽。一、基本操作
# 增 models.Tb1.objects.create(c1='xx', c2='oo') #增加一條數據,可以接受字典類型數據 **kwargs obj = models.Tb1(c1='xx', c2='oo') obj.save() dic = {'c1':'xx','c2':'oo'} models.Tb1.objects.create(**dic) #Form的產出結果是一個字典,可以根據這個Form的字典和**直接在數據庫創建數據 # 查 models.Tb1.objects.get(id=123) # 獲取單條數據,不存在則報錯(不建議) models.Tb1.objects.all() # 獲取全部 .first() 取第一條數據 models.Tb1.objects.filter(name='seven') # 獲取指定條件的數據 也可以用**的方式傳參數 # 刪 models.Tb1.objects.filter(name='seven').delete() # 刪除指定條件的數據 # 改 models.Tb1.objects.filter(name='seven').update(gender='0') # 將指定條件的數據更新,均支持 **kwargs obj = models.Tb1.objects.get(id=1) obj.c1 = '111' obj.save() # 修改單條數據
細看從數據庫取出的數據類型 :
w = models.Simp.objects.all() print w, type(w) [<Simp: chenc>, <Simp: zan>, <Simp: zhangsan>] <class 'django.db.models.query.QuerySet'>
可以看到,從數據庫取出個數據看起來像包含對象的列表。而實際上整個數據為django中的特殊類型QuerySet。
.all()是取得所有列的數據,可以加.values()取出某一列,每一項的值為一個字典:
w = models.Simp.objects.all().values('username') print w, type(w) [{'username': u'chenc'}, {'username': u'zan'}, {'username': u'zhangsan'}] <class 'django.db.models.query.QuerySet'>
.values_list(),獲取到的值為一個元組
w = models.Simp.objects.all().values_list('username') print w, type(w) [(u'chenc',), (u'zan',), (u'zhangsan',)] <class 'django.db.models.query.QuerySet'>
.values_list()也可以添加多個參數:(可以配合Form在前端生成動態的select)
w = models.Simp.objects.all().values_list('id', 'username') print w, type(w) [(1, u'chenc'), (2, u'zan'), (3, u'zhangsan')] <class 'django.db.models.query.QuerySet'>
query可以查看執行的sql語句:
b = models.Simp.objects.all() print b.query SELECT "app01_simp"."id", "app01_simp"."username", "app01_simp"."password" FROM "app01_simp"
二、進階操作
利用雙下劃線將字段和對應的操作連接起來
# 獲取個數 # # models.Tb1.objects.filter(name='seven').count() # 大于,小于 # # models.Tb1.objects.filter(id__gt=1) # 獲取id大于1的值 # models.Tb1.objects.filter(id__lt=10) # 獲取id小于10的值 # models.Tb1.objects.filter(id__lt=10, id__gt=1) # 獲取id大于1 且 小于10的值 # in # # models.Tb1.objects.filter(id__in=[11, 22, 33]) # 獲取id等于11、22、33的數據 # models.Tb1.objects.exclude(id__in=[11, 22, 33]) # not in # contains # # models.Tb1.objects.filter(name__contains="ven") # models.Tb1.objects.filter(name__icontains="ven") # icontains大小寫不敏感 # models.Tb1.objects.exclude(name__icontains="ven") # range # # models.Tb1.objects.filter(id__range=[1, 2]) # 范圍bettwen and # 其他類似 # # startswith,istartswith, endswith, iendswith, # order by # # models.Tb1.objects.filter(name='seven').order_by('id') # asc 從小到大 # models.Tb1.objects.filter(name='seven').order_by('-id') # desc 從大到小 # limit 、offset # # models.Tb1.objects.all()[10:20] # group by from django.db.models import Count, Min, Max, Sum # models.Tb1.objects.filter(c1=1).values('id').annotate(c=Count('num')) # SELECT "app01_tb1"."id", COUNT("app01_tb1"."num") AS "c" FROM "app01_tb1" WHERE "app01_tb1"."c1" = 1 GROUP BY "app01_tb1"."id"
三、操作表之一對多實例
我們來創建一個完整的過程 特別聲明:(過程繁瑣無聊,純屬作者梳理思路,可以直接跳過看解析)
首先我們先來創造兩張表,并設置外鍵。
class GroupNew(models.Model): groupname = models.CharField(max_length=15) class UserNew(models.Model): user = models.CharField(max_length=15) 10 group = models.ForeignKey(GroupNew)
然后再組表里創建幾條數據,配置好url生成數據:
# coding:utf-8 from django.shortcuts import HttpResponse,render from app01 import models def Foreign(request): models.GroupNew.objects.create(groupname='CEO') models.GroupNew.objects.create(groupname='CTO') models.GroupNew.objects.create(groupname='COO') return HttpResponse('OK')
創建用于生成表單的form:(動態的select)
# coding:utf-8 from django import forms from app01 import models class CreateForm(forms.Form): user = forms.CharField(max_length=20) group = forms.IntegerField(widget=forms.Select()) def __init__(self, *args, **kwargs): super(CreateForm, self).__init__(*args, **kwargs) self.fields['group'].widget.choices = models.GroupNew.objects.all().values_list('id', 'groupname')
在views.py里寫好創建用戶的方法,并應用form:
from app01.forms import foreign as UserForm def createuser(request): obj = UserForm.CreateForm() return render(request, 'foreign/createuser.html', {'obj': obj})
創建一個html頁面,用來在前端操作創建用戶:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title></title> </head> <body> <form action="/createuser/" method="post"> <p>{{ obj.user }}</p> <p>{{ obj.group }}</p> <input type="submit" value="提交" /> </form> </body> </html>
配置好url訪問成功:
現在我們要來創建用戶數據:(兩種方法)
def createuser(request): obj = UserForm.CreateForm(request.POST) if request.method == 'POST': if obj.is_valid(): all_data = obj.clean() group_id = all_data['group'] username = all_data['user'] # 1、先獲取字典表里的數據對象 # group_obj = models.GroupNew.objects.get(id=group_id) # # 創建用戶數據 # models.UserNew.objects.create(user=username, group=group_obj) # 2、 直接傳group_id不需獲取對象 models.UserNew.objects.create(user=username, group_id=group_id) else: pass return render(request, 'foreign/createuser.html', {'obj': obj})
還有一種方法是根據Form的修改來創建:(注意:前端頁面也需要加上_id與之匹配{{ obj.group_id }} )
forms.py
# coding:utf-8 from django import forms from app01 import models class CreateForm(forms.Form): user = forms.CharField(max_length=20) group_id = forms.IntegerField(widget=forms.Select()) #根據數據庫存的字段來修改這里的form使之與數據庫相同 def __init__(self, *args, **kwargs): super(CreateForm, self).__init__(*args, **kwargs) self.fields['group_id'].widget.choices = models.GroupNew.objects.all().values_list('id', 'groupname')
然后再vires.py里面就可以直接拿到前端傳來的字典,直接創建數據了。注意用**的方式傳參
from app01.forms import foreign as UserForm def createuser(request): obj = UserForm.CreateForm(request.POST) if request.method == 'POST': if obj.is_valid(): all_data = obj.clean() print all_data # group_id = all_data['group'] username = all_data['user'] # 1、先獲取字典表里的數據對象 # group_obj = models.GroupNew.objects.get(id=group_id) # # 創建用戶數據 # models.UserNew.objects.create(user=username, group=group_obj) # 2、 直接傳group_id不需獲取對象 models.UserNew.objects.create(**all_data) #用**的方式傳遞字典參數 else: pass return render(request, 'foreign/createuser.html', {'obj': obj})
下面我們可以來展示一下數據:
在views.pu里把數據全部拿到,返回到前端:
from app01.forms import foreign as UserForm def createuser(request): obj = UserForm.CreateForm(request.POST) if request.method == 'POST': if obj.is_valid(): all_data = obj.clean() models.UserNew.objects.create(**all_data) else: pass user_list = models.UserNew.objects.all() #獲取到表中的全部數據 return render(request, 'foreign/createuser.html', {'obj': obj, 'user_list': user_list})
四、前端和后臺獲取數據 (了不起的雙下劃線“__”)
前端頁面獲取數據展示:
在前端頁面不能顯示用戶組的id,而是直接顯示用戶組的名稱
因為外鍵對應的字段是一個對象,這個對象代指的是字典表中的一行數據,所以我們在前端取到字典表中的數據用“.”獲取
<table> {% for item in user_list %} <tr> <td>{{ item.user }}</td> <td>{{ item.group.groupname }}</td> 從對象中獲取數據用"." </tr> {% endfor %} </table>
后臺獲取數據:(了不起的雙下劃線)
我們在前端用get的方法獲取數據,
在瀏覽器的url后追加字符 http://127.0.0.1:8000/createuser/?group=CEO
例如:我們要展示CEO組里面所以得用戶,在views里要如何寫呢?
from app01.forms import foreign as UserForm def createuser(request): obj = UserForm.CreateForm(request.POST) if request.method == 'POST': if obj.is_valid(): all_data = obj.clean() models.UserNew.objects.create(**all_data) else: pass val = request.GET.get('group') user_list = models.UserNew.objects.filter(group__groupname=val) # 去字典表里的數據時用雙下劃線 return render(request, 'foreign/createuser.html', {'obj': obj, 'user_list': user_list})
五、解析與總結
所有的聯表操作只需理解一點:
model中一般字段為字符串,而外鍵代表的是一個對象,這個對象就是字典表中的一行數據。
創建數據:
1、根據對象級別來操作表。
表中有外鍵的字段代指的就是另外一張表的一行數據。在Models里的表現形式就是一個對象,那么我們創建這張表時,給外鍵的字段傳值時也應該傳一個對象,而從前臺獲取到的是一個數字“1”,1不是一個對象,根據這個“1”先創建一個字典表的對象,所以根據前臺的“1”先獲取字典表里對應的數據對象,把這個對象傳遞到創建表時所需的對象參數即可。
(其實也是把對象轉換成sql語句拼接成帶_id的樣式,有一種多此一舉的感覺)
2、根據數據庫級別來操作表。
首先我們可以先查看一下數據庫表中的外鍵值的樣式 user_group_id。“_id”在models沒有定義的,是django自動為我們定義的樣式。所以我們在向數據庫中插入數據的時候,外鍵的字段應該加上_id,這樣就可以直接傳從前臺獲取的數字了。
(可以再form中修改外鍵的值,加"_id",這樣傳到后臺的數據就能直接拿到一個字典,在用**的方式傳值創建數據)
獲取數據:
跨表取數據用 "."
因為在models里的外鍵代指的是另外一張表的一行數據,且這個數據類型為一個對象。
那么就可以根據這個對象直接找到那行數據里對應的字段。用 “.”獲取
在前端頁面就可以{{item.group.groupname}}方式獲取到。
跨表過濾數據時用 “__”
過濾數據用雙下劃線 “__”(group__groupname=val),如果有多張表建立外鍵繼續用雙下劃線“__”跨表查詢數據
看完上述內容,你們掌握怎么在Django中利用Model操作表的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注創新互聯行業資訊頻道,感謝各位的閱讀!
分享標題:怎么在Django中利用Model操作表-創新互聯
當前鏈接:http://vcdvsql.cn/article32/eghsc.html
成都網站建設公司_創新互聯,為您提供網站建設、網站設計公司、營銷型網站建設、網站營銷、域名注冊、網站導航
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯