第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

關(guān)于django restframework的條件查詢問題

關(guān)于django restframework的條件查詢問題

紫衣仙女 2018-08-10 17:05:02
一個(gè)接口:http://127.0.0.1:8000/api/v1/course/ 對應(yīng)的處理視圖如下class CourseView(APIView):     # renderer_classes = [JSONRenderer,]     def get(self, request, *args, **kwargs):         ret = {"code": 1}        try:             queryset = models.Course.objects.all()             ser = CourseSerializer(instance=queryset, many=True)             ret["data"] = ser.data        except Exception as e:             ret["code"] = 0             ret["msg"] = "獲取數(shù)據(jù)失敗"         return Response(ret)該接口是不帶參數(shù)的,返回的也是.all()全部的數(shù)據(jù)。那么問題來了,如果我要寫一個(gè)接口 api/products/,這個(gè)接口呢,假如有三個(gè)非必填參數(shù),比如產(chǎn)品名稱:name(可以模糊查詢),產(chǎn)品類型:type;生產(chǎn)時(shí)間:time。如果一個(gè)參數(shù)都不帶,name就返回 .all()全部數(shù)據(jù),這個(gè)問題該如何處理呢?我現(xiàn)在的想法是:1/判斷是否帶參數(shù) 若果不帶參數(shù),就返回.all()2/如帶了一個(gè)或多個(gè)參數(shù),就用.filter(key1 = value1,key2=value2 ...)這樣的形式去查數(shù)據(jù)。思考了一下,如果以這樣的形式去判斷參數(shù)邏輯是否太復(fù)雜?或者我這樣的想法是錯(cuò)誤的。因?yàn)閟erializer,比如上面的CourseSerializer對象instance參數(shù)需要傳入的是一個(gè).all()的queryset對象。restframework 有沒有處理像過濾查詢,模糊搜索查詢的組件。有沒有上面資料指點(diǎn)一下。
查看完整描述

1 回答

?
拉風(fēng)的咖菲貓

TA貢獻(xiàn)1995條經(jīng)驗(yàn) 獲得超2個(gè)贊

1.忘記all(),全部用filter().filter()在無條件的時(shí)候=all()
2.現(xiàn)在我們需要的是判斷是否存在條件.

# 變量名盡量不要用time 和type,他們分別是內(nèi)置模塊名和內(nèi)置方法名. name = request.GET.get("name")
type = request.GET.get("type")
time = request.GET.get("time")# 現(xiàn)在我們有了三個(gè)條件.判斷他們是否存在,如果存在就要作為條件傳給filter()kwargs = {}if name:
    kwargs["name__contains"] = nameif type:
    kwargs["type"] = typeif time:
    kwargs["time"] = time
queryset = models.Course.objects.filter(**kwargs)# 后同


查看完整回答
反對 回復(fù) 2018-08-12
  • 1 回答
  • 0 關(guān)注
  • 1969 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號