成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

怎么在Django中利用Model操作表-創(chuàng)新互聯(lián)

怎么在Django中利用Model操作表?相信很多沒有經(jīng)驗的人對此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個問題。

創(chuàng)新互聯(lián)公司是創(chuàng)新、創(chuàng)意、研發(fā)型一體的綜合型網(wǎng)站建設(shè)公司,自成立以來公司不斷探索創(chuàng)新,始終堅持為客戶提供滿意周到的服務,在本地打下了良好的口碑,在過去的十載時間我們累計服務了上千家以及全國政企客戶,如人造霧等企業(yè)單位,完善的項目管理流程,嚴格把控項目進度與質(zhì)量監(jiān)控加上過硬的技術(shù)實力獲得客戶的一致贊譽。

一、基本操作

# 增

models.Tb1.objects.create(c1='xx', c2='oo') #增加一條數(shù)據(jù),可以接受字典類型數(shù)據(jù) **kwargs

obj = models.Tb1(c1='xx', c2='oo')
obj.save()

  dic = {'c1':'xx','c2':'oo'}
  models.Tb1.objects.create(**dic)   #Form的產(chǎn)出結(jié)果是一個字典,可以根據(jù)這個Form的字典和**直接在數(shù)據(jù)庫創(chuàng)建數(shù)據(jù)
# 查

models.Tb1.objects.get(id=123)     # 獲取單條數(shù)據(jù),不存在則報錯(不建議)
models.Tb1.objects.all()        # 獲取全部   .first() 取第一條數(shù)據(jù)
models.Tb1.objects.filter(name='seven') # 獲取指定條件的數(shù)據(jù)  也可以用**的方式傳參數(shù)

# 刪

models.Tb1.objects.filter(name='seven').delete() # 刪除指定條件的數(shù)據(jù)

# 改

models.Tb1.objects.filter(name='seven').update(gender='0') # 將指定條件的數(shù)據(jù)更新,均支持 **kwargs

obj = models.Tb1.objects.get(id=1)
obj.c1 = '111'
obj.save()                         # 修改單條數(shù)據(jù)

細看從數(shù)據(jù)庫取出的數(shù)據(jù)類型 :

w = models.Simp.objects.all()
 print w, type(w)
[<Simp: chenc>, <Simp: zan>, <Simp: zhangsan>]  <class 'django.db.models.query.QuerySet'>

可以看到,從數(shù)據(jù)庫取出個數(shù)據(jù)看起來像包含對象的列表。而實際上整個數(shù)據(jù)為django中的特殊類型QuerySet。

.all()是取得所有列的數(shù)據(jù),可以加.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()也可以添加多個參數(shù):(可以配合Form在前端生成動態(tài)的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可以查看執(zhí)行的sql語句:

b = models.Simp.objects.all()
print b.query

SELECT "app01_simp"."id", "app01_simp"."username", "app01_simp"."password" FROM "app01_simp"

二、進階操作

利用雙下劃線將字段和對應的操作連接起來

# 獲取個數(shù)
  #
  # 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的數(shù)據(jù)
  # 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"

三、操作表之一對多實例

我們來創(chuàng)建一個完整的過程 特別聲明:(過程繁瑣無聊,純屬作者梳理思路,可以直接跳過看解析)

首先我們先來創(chuàng)造兩張表,并設(shè)置外鍵。

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)

然后再組表里創(chuàng)建幾條數(shù)據(jù),配置好url生成數(shù)據(jù):

# 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')

創(chuàng)建用于生成表單的form:(動態(tài)的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里寫好創(chuàng)建用戶的方法,并應用form:

from app01.forms import foreign as UserForm


def createuser(request):

  obj = UserForm.CreateForm()

  return render(request, 'foreign/createuser.html', {'obj': obj})

創(chuàng)建一個html頁面,用來在前端操作創(chuàng)建用戶:

<!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訪問成功:

怎么在Django中利用Model操作表

現(xiàn)在我們要來創(chuàng)建用戶數(shù)據(jù):(兩種方法)

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、先獲取字典表里的數(shù)據(jù)對象
      # group_obj = models.GroupNew.objects.get(id=group_id)
      # # 創(chuàng)建用戶數(shù)據(jù)
      # 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})

還有一種方法是根據(jù)Form的修改來創(chuàng)建:(注意:前端頁面也需要加上_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()) #根據(jù)數(shù)據(jù)庫存的字段來修改這里的form使之與數(shù)據(jù)庫相同

  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里面就可以直接拿到前端傳來的字典,直接創(chuàng)建數(shù)據(jù)了。注意用**的方式傳參

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、先獲取字典表里的數(shù)據(jù)對象
      # group_obj = models.GroupNew.objects.get(id=group_id)
      # # 創(chuàng)建用戶數(shù)據(jù)
      # models.UserNew.objects.create(user=username, group=group_obj)

      # 2、 直接傳group_id不需獲取對象

      models.UserNew.objects.create(**all_data)  #用**的方式傳遞字典參數(shù)

    else:
      pass
  return render(request, 'foreign/createuser.html', {'obj': obj})

下面我們可以來展示一下數(shù)據(jù):

在views.pu里把數(shù)據(jù)全部拿到,返回到前端:

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()  #獲取到表中的全部數(shù)據(jù)

  return render(request, 'foreign/createuser.html', {'obj': obj, 'user_list': user_list})

四、前端和后臺獲取數(shù)據(jù) (了不起的雙下劃線“__”)

前端頁面獲取數(shù)據(jù)展示:

在前端頁面不能顯示用戶組的id,而是直接顯示用戶組的名稱

因為外鍵對應的字段是一個對象,這個對象代指的是字典表中的一行數(shù)據(jù),所以我們在前端取到字典表中的數(shù)據(jù)用“.”獲取

<table>
    {% for item in user_list %}
      <tr>
        <td>{{ item.user }}</td>
        <td>{{ item.group.groupname }}</td>  從對象中獲取數(shù)據(jù)用"."
      </tr>
    {% endfor %}
  </table>

后臺獲取數(shù)據(jù):(了不起的雙下劃線)

我們在前端用get的方法獲取數(shù)據(jù),

在瀏覽器的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)  # 去字典表里的數(shù)據(jù)時用雙下劃線

  return render(request, 'foreign/createuser.html', {'obj': obj, 'user_list': user_list})

五、解析與總結(jié)

所有的聯(lián)表操作只需理解一點:
model中一般字段為字符串,而外鍵代表的是一個對象,這個對象就是字典表中的一行數(shù)據(jù)。

怎么在Django中利用Model操作表

創(chuàng)建數(shù)據(jù):

1、根據(jù)對象級別來操作表。
表中有外鍵的字段代指的就是另外一張表的一行數(shù)據(jù)。在Models里的表現(xiàn)形式就是一個對象,那么我們創(chuàng)建這張表時,給外鍵的字段傳值時也應該傳一個對象,而從前臺獲取到的是一個數(shù)字“1”,1不是一個對象,根據(jù)這個“1”先創(chuàng)建一個字典表的對象,所以根據(jù)前臺的“1”先獲取字典表里對應的數(shù)據(jù)對象,把這個對象傳遞到創(chuàng)建表時所需的對象參數(shù)即可。
(其實也是把對象轉(zhuǎn)換成sql語句拼接成帶_id的樣式,有一種多此一舉的感覺)

2、根據(jù)數(shù)據(jù)庫級別來操作表。
首先我們可以先查看一下數(shù)據(jù)庫表中的外鍵值的樣式 user_group_id?!癬id”在models沒有定義的,是django自動為我們定義的樣式。所以我們在向數(shù)據(jù)庫中插入數(shù)據(jù)的時候,外鍵的字段應該加上_id,這樣就可以直接傳從前臺獲取的數(shù)字了。
(可以再form中修改外鍵的值,加"_id",這樣傳到后臺的數(shù)據(jù)就能直接拿到一個字典,在用**的方式傳值創(chuàng)建數(shù)據(jù))

獲取數(shù)據(jù):

跨表取數(shù)據(jù)用 "."
因為在models里的外鍵代指的是另外一張表的一行數(shù)據(jù),且這個數(shù)據(jù)類型為一個對象。
那么就可以根據(jù)這個對象直接找到那行數(shù)據(jù)里對應的字段。用 “.”獲取
在前端頁面就可以{{item.group.groupname}}方式獲取到。

跨表過濾數(shù)據(jù)時用 “__”
過濾數(shù)據(jù)用雙下劃線 “__”(group__groupname=val),如果有多張表建立外鍵繼續(xù)用雙下劃線“__”跨表查詢數(shù)據(jù)

看完上述內(nèi)容,你們掌握怎么在Django中利用Model操作表的方法了嗎?如果還想學到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!

分享標題:怎么在Django中利用Model操作表-創(chuàng)新互聯(lián)
當前鏈接:http://jinyejixie.com/article32/eghsc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站建設(shè)網(wǎng)站設(shè)計公司、營銷型網(wǎng)站建設(shè)、網(wǎng)站營銷、域名注冊網(wǎng)站導航

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都seo排名網(wǎng)站優(yōu)化
渭南市| 湘潭县| 额尔古纳市| 红原县| 元朗区| 岑溪市| 乐平市| 花莲市| 佛冈县| 平原县| 平利县| 界首市| 绥江县| 门头沟区| 阳春市| 宽城| 沧州市| 莆田市| 大关县| 韩城市| 邢台县| 尚志市| 阳谷县| 泰宁县| 文成县| 阜平县| 吐鲁番市| 文成县| 尚义县| 尚义县| 贡觉县| 云梦县| 沧州市| 会同县| 长泰县| 普定县| 长岛县| 隆化县| 黄山市| 大田县| 濮阳市|