Django ORM資料查詢方法,query檢視內部封裝sql語句
阿新 • • 發佈:2022-03-03
必知必會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',
},
}
}