欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python中Django的ORM高級用法

 更新時間:2023年07月27日 10:10:14   作者:魏志標  
這篇文章主要介紹了Python中Django的ORM高級用法,ORM是一種思想,ORM對象-關系映射,關系數據庫是企業(yè)級應用環(huán)境中永久存放數據的主流數據存儲系統(tǒng),需要的朋友可以參考下

一、模糊查詢

contains

查詢某個屬性中包含某個數據結果

def stuinfo(request):
    ##查詢字段中包含某個內容
    data_list = stu.objects.filter(name__contains="華")
    for item in data_list:
        print(item.name)
    return HttpResponse("查詢成功") 

在這里插入圖片描述

startswith、endswith

def stuinfo(request):
    ###查詢以什么開頭的內容
    stu_start = stu.objects.filter(name__startswith="張")
    for item in stu_start:
        print(item.name)
    return HttpResponse("查詢成功")    

在這里插入圖片描述

def stuinfo(request):
    ###查詢以什么結尾的結尾
    stu_end = stu.objects.filter(name__endswith="華")
    for item in stu_end:
        print(item.name)
    return HttpResponse("查詢成功"  

在這里插入圖片描述

注釋:以上運算符都區(qū)分大小寫,在這些運算符前加上i表示不區(qū)分大小寫,如iexact、icontains、istartswith、iendswith.

isnull

查看某個字段為空的記錄

def stuinfo(request):
    ###比較大小
    null_stu = stu.objects.filter(description__isnull=True)  ##查詢description為空的數據結果
    for item in null_stu:
        print(item.age)
    return HttpResponse("查詢成功")

比較查詢

gt 大于 (greater then)
gte 大于等于 (greater then equal)
lt 小于 (less then)
lte 小于等于 (less then equal)
def stuinfo(request):
    ###比較大小
    age_stu = stu.objects.filter(age__gt=22)    ###查詢年齡大于22的結果
    for item in age_stu:
        print(item.age)
    return HttpResponse("查詢成功") 

日期查詢

year、month、day、week_day、hour、minute、second:對日期時間類型的屬性進行運算。

from django.utils import timezone as datetime
def stuinfo(request):
    ###根據日期進行查詢
    time_stu = stu.objects.filter(create_time__gt=datetime.datetime(2020,11,20))  ##查看創(chuàng)建時間在2020年11月20日之后的數據
    print(time_stu)
    return HttpResponse("查詢成功")

二、進階查詢

F查詢

之前的查詢都是對象的屬性與常量值比較,兩個屬性怎么比較呢? 答:使用F對象,被定義在django.db.models中。

from django.db.models import F
def stuinfo(request):
    ###F查詢,不同屬性之間進行比較
    stu.objects.filter(id=1).update(update_time="2022-5-22")   ###更新某個字段的數據
    f_stu = stu.objects.get(id=1)
    print(f_stu.name)
    stu_list = stu.objects.exclude(create_time=F("update_time"))  ##查看創(chuàng)建時間和更新時間不一樣的數據
    print(stu_list)  
    return HttpResponse("查詢成功")

在這里插入圖片描述

Q查詢

多個過濾器逐個調用表示邏輯與關系,同sql語句中where部分的and關鍵字。

如果需要實現邏輯或or的查詢,需要使用Q()對象結合|運算符,Q對象被義在django.db.models中。

from django.db.models import Q
def stuinfo(request):
    ###Q查詢,不同屬性之間進行比較,類似sql中邏輯或,與的關系
    ##查看年齡小于19或者大于22
    q_stu = stu.objects.filter(Q(age__lt=19) | Q(age__gt=22)).all()
    for item in q_stu:
        print(item.age)
    return HttpResponse("查詢成功")  

在這里插入圖片描述

Q對象可以使用&、|連接,&表示邏輯與,|表示邏輯或**

from django.db.models import Q
def stuinfo(request):
    ##查看年齡不等于22的
    q_stu = stu.objects.filter(~Q(age=22))
    for item in q_stu:
        print(item.age)
    return HttpResponse("查詢成功") 

在這里插入圖片描述

聚合查詢

使用aggregate()過濾器調用聚合函數。聚合函數包括:Avg 平均,Count 數量,Max 最大,Min 最小,Sum 求和,被定義在django.db.models中。

注意:aggregate的返回值是一個字典類型,格式如下:

 {'屬性名__聚合類小寫':值}
from django.db.models import Sum,Count,Avg,Max,Min
def stuinfo(request):
   ###聚合查詢聚合函數包括:Avg 平均,Count 數量,Max 最大,Min 最小,Sum 求和
   ##查看數量
   stu_count = stu.objects.count()     ##使用count時一般不使用aggregate()過濾器。
   print(stu_count)
   #查詢平均年齡
   avg_stu = stu.objects.aggregate(Avg('age'))
   print(avg_stu)
   ##最大值
   max_stu = stu.objects.aggregate(Max('age'))
   print(max_stu)
   return HttpResponse("查詢成功")

在這里插入圖片描述

到此這篇關于Python中Django的ORM高級用法的文章就介紹到這了,更多相關Django的ORM高級用法內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 解決python3安裝pandas出錯的問題

    解決python3安裝pandas出錯的問題

    這篇文章主要介紹了解決python3安裝pandas出錯的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-05-05
  • Python分支結構和循環(huán)結構示例代碼

    Python分支結構和循環(huán)結構示例代碼

    在Python中,分支結構通過if、elif和else關鍵字來實現條件判斷,在使用if語句時,程序會根據條件表達式的真假執(zhí)行相應的代碼塊,這篇文章主要介紹了Python分支結構和循環(huán)結構,需要的朋友可以參考下
    2024-03-03
  • Python如何根據時間序列數據作圖

    Python如何根據時間序列數據作圖

    這篇文章主要介紹了Python如何根據時間序列數據作圖,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-05-05
  • python流程圖和思維導圖實例代碼

    python流程圖和思維導圖實例代碼

    這篇文章主要給大家介紹了關于python流程圖和思維導圖的相關資料,學習python過程中,畫流程圖可以有效的幫助你梳理程序的邏輯,本文通過示例代碼介紹的非常詳細,需要的朋友可以參考下
    2021-08-08
  • python中使用 xlwt 操作excel的常見方法與問題

    python中使用 xlwt 操作excel的常見方法與問題

    這篇文章主要給大家介紹了關于python中使用 xlwt 操作excel的常見方法與問題的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-01-01
  • 詳解?PyTorch?Lightning模型部署到生產服務中

    詳解?PyTorch?Lightning模型部署到生產服務中

    這篇文章主要為大家介紹了如何將PyTorch?Lightning模型部署到生產服務中的詳細教程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-09-09
  • pytorch索引查找 index_select的例子

    pytorch索引查找 index_select的例子

    今天小編就為大家分享一篇pytorch索引查找 index_select的例子,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-08-08
  • 使用Python實現將Excel表格插入到Word文檔中

    使用Python實現將Excel表格插入到Word文檔中

    在日常辦公場景中,通過Python腳本自動化整合Excel數據與Word文檔,能夠實現表格的智能遷移,滿足不同場景下數據呈現的專業(yè)性要求,下面小編就來為大家介紹一下具體實現的三種方法吧
    2025-03-03
  • pyecharts如何使用formatter回調函數的問題

    pyecharts如何使用formatter回調函數的問題

    這篇文章主要介紹了pyecharts如何使用formatter回調函數的問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • 推薦8款常用的Python GUI圖形界面開發(fā)框架

    推薦8款常用的Python GUI圖形界面開發(fā)框架

    這篇文章主要介紹了推薦8款常用的Python GUI圖形界面開發(fā)框架,需要的朋友可以參考下
    2020-02-02

最新評論