081:QuerySet API详解-values和values_list

QuerySet API详解-values和values_list:

values用来指定在提取数据出来,需要提取哪些字段。默认情况下会把表中所有的字段全部都提取出来,可以使用values来进行指定,并且使用了values方法后,提取出的QuerySet中的数据类型不是模型,而是在values方法中指定的字段和值形成的字典:

    # books = Book.objects.values("id", "name", "price")
    # books = Book.objects.values("id", "name", author_name=F("author__name"))
    books = Book.objects.values("id", "name", sum=Count("bookorder__id"))

    print(books)
    for item in books:
        print(item)

以上打印出来的article是类似于{"title":"abc","content":"xxx"}的形式。如果在values中没有传递任何参数,那么将会返回这个恶模型中所有的属性。

values_list类似于values。只不过返回的QuerySet中,存储的不是字典,而是元组。示例代码如下:

    # books = Book.objects.values_list()
    books = Book.objects.values_list("id", "name")
    print(books)
    for item in books:
        print(item)

那么在打印articles后,结果为<QuerySet [(1,'abc'),(2,'xxx'),...]>等。如果在values_list中只有一个字段。那么你可以传递flat=True来将结果扁平化。示例代码如下:

books = Book.objects.values_list("name", flat=True)

工程实例截图:

 

转载于:https://www.cnblogs.com/zheng-weimin/p/10274709.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值