1. 程式人生 > 其它 >Django ORM資料查詢方法,query檢視內部封裝sql語句

Django ORM資料查詢方法,query檢視內部封裝sql語句

必知必會13條:ORM資料查詢方法

準備環境:

id name age register_time
18 junjie 18 2004-01-01
19 nn 10 2004-01-01
20 tom 99 2022-03-02

方法:

方法 描述
all() 查詢所有資料
filter() 帶有過濾條件的查詢
get() 直接拿到資料物件
但條件不存在直接報錯
first() 拿queryset的第一個元素
values() 可指定獲取的資料欄位
values_list() 列表套元祖
distinct() 去重
order_by() 預設升序
order_by() order_by('—欄位名') 降序
count() 統計當前資料個數
exclude() 展示指定資料之外的資料
exists() 資料本身就自帶布林值 返回的是布林值

all():查詢所有資料

res = models.User.objects.all()
print(res)
# 輸出:<QuerySet [<User: 物件>>>junjie>, <User: 物件>>>nn>, <User: 物件>>>tom>]>

filter():帶有過濾條件的查詢

res = models.User.objects.filter(pk=20)
print(res)
# 輸出:<QuerySet [<User: 物件>>>tom>]>

get():直接拿到資料物件,但條件不存在直接報錯

res = models.User.objects.get(pk=20)
print(res)
# 輸出:物件>>>tom

first():拿queryset的第一個元素

res = models.User.objects.all().first()
print(res)
# 輸出:物件>>>junjie

values():可指定獲取的資料欄位, 結果列表套字典。

res = models.User.objects.values('name','age')
print(res)
# 輸出:<QuerySet [{'name': 'junjie', 'age': 18}, {'name': 'nn', 'age': 10}, {'name': 'tom', 'age': 99}]>

values_list() :列表套元祖

res = models.User.objects.values_list('name')
print(res)
# 輸出:<QuerySet [('junjie',), ('nn',), ('tom',)]>

distinct():去重

注意:去重一定是要一模一樣的資料,請忽略主鍵。

res = models.User.objects.values('name','age').distinct()
print(res)

order_by():升序

res = models.User.objects.order_by('age')
print(res)
# 輸出:<QuerySet [<User: 物件>>>nn>, <User: 物件>>>junjie>, <User: 物件>>>tom>]>

order_by():降序

res = models.User.objects.order_by('-age')
print(res)
# 輸出:<QuerySet [<User: 物件>>>tom>, <User: 物件>>>junjie>, <User: 物件>>>nn>]>

count():統計當前資料的個數

res = models.User.objects.count()
print(res) 
# 輸出: 3

exclude():獲取指定之外的資料

res = models.User.objects.exclude(name='junjie')
print(res)
# 輸出:<QuerySet [<User: 物件>>>nn>, <User: 物件>>>tom>]>

exists():資料本身就自帶布林值 返回的是布林值

注意:資料存在返回Ture, 不存在返回Flase

res = models.User.objects.exclude(name='junjie').exists()
print(res)
# 輸出: True

檢視內部封裝的sql語句,只有queryset物件才能夠點選query檢視內部的sql語句

res = models.User.objects.values_list('name')
print(res.query)
# 輸出:SELECT `app01_user`.`name` FROM `app01_user`

直接檢視內部sql語句的方式,settings輔助程式碼

# 去配置檔案中配置一下即可
LOGGING = {
    'version': 1,
    'disable_existing_loggers': False,
    'handlers': {
        'console':{
            'level':'DEBUG',
            'class':'logging.StreamHandler',
        },
    },
    'loggers': {
        'django.db.backends': {
            'handlers': ['console'],
            'propagate': True,
            'level':'DEBUG',
        },
    }
}