在线观看不卡亚洲电影_亚洲妓女99综合网_91青青青亚洲娱乐在线观看_日韩无码高清综合久久

鍍金池/ 問答/Python/ 關(guān)于django restframework的條件查詢問題(新手勿噴)

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

一個接口: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ù)。

那么問題來了,如果我要寫一個接口 api/products/,這個接口呢,假如有三個非必填參數(shù),比如
產(chǎn)品名稱:name(可以模糊查詢),產(chǎn)品類型:type;生產(chǎn)時間:time。
如果一個參數(shù)都不帶,name就返回 .all()全部數(shù)據(jù),

這個問題該如何處理呢?

我現(xiàn)在的想法是:
1/判斷是否帶參數(shù) 若果不帶參數(shù),就返回.all()
2/如帶了一個或多個參數(shù),就用.filter(key1 = value1,key2=value2 ...)這樣的形式去查數(shù)據(jù)。
思考了一下,如果以這樣的形式去判斷參數(shù)邏輯是否太復(fù)雜?或者我這樣的想法是錯誤的。因為serializer,比如上面的CourseSerializer對象instance參數(shù)需要傳入的是一個.all()的queryset對象。

restframework 有沒有處理像過濾查詢,模糊搜索查詢的組件。有沒有上面資料指點一下。


回答
編輯回答
下墜

1.忘記all(),全部用filter().filter()在無條件的時候=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)在我們有了三個條件.判斷他們是否存在,如果存在就要作為條件傳給filter()
kwargs = {}
if name:
    kwargs["name__contains"] = name
if type:
    kwargs["type"] = type
if time:
    kwargs["time"] = time
queryset = models.Course.objects.filter(**kwargs)
# 后同
2017年12月24日 15:25