zoukankan      html  css  js  c++  java
  • 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)

    工程实例截图:

  • 相关阅读:
    Git的使用
    Ninject.Extensions.
    centos6的安装
    ASP.NET 5+EntityFramework 7
    Nancy和MVC的简单对比
    ASP.NET 5应用是如何运行的(3)
    映射层超类型
    缓存模块
    怎样的中奖算法能让人信服(转)
    JQuery Easy Ui (Tree树)详解(转)
  • 原文地址:https://www.cnblogs.com/zheng-weimin/p/10274709.html
Copyright © 2011-2022 走看看