zoukankan      html  css  js  c++  java
  • ORM

    model一般都是有多个属性的,但是很多时候我们又只需要查询特定的某一个,这个时候可以用到valuesvalues_list

    利用values

    from attendence.models import Employee
    from attendence.models import EmployeeIP
    
    #获取一个字段
    ipList = EmployeeIP.objects.values("IP").first()
    print(type(ipList))
    # <class 'dict'>
    print(ipList)
    # {'IP': '192.168.1.41'}
    
    #获取多个字段
    empList = Employee.objects.values("first_name", "last_name", "email")[0:2]
    print(type(empList))
    # <class 'django.db.models.query.QuerySet'>
    print(empList)
    # [
    #   {'last_name': 'Wei', 'first_name': 'Vena', 'email': 'Vena@test.com'},
    #   {'last_name': 'Wan', 'first_name': 'Mark', 'email': 'mwan@test.com'}
    # ]
    

      

    利用values_list

    ipList = EmployeeIP.objects.values_list("IP").first()
    print(type(ipList))
    # <class 'tuple'>
    print(ipList)
    # ('192.168.1.111',)
    
    ipList = EmployeeIP.objects.values_list("IP")[0:2]
    print(type(ipList))
    # <class 'django.db.models.query.QuerySet'>
    print(ipList)
    # [('192.168.1.41',), ('192.168.1.44',)]
    print(type(ipList[0]))
    # <class 'tuple' >
    print(ipList[0])
    # 192.168.1.111
    

      

    values和values_list的差别

    从上面的代码中我们可以看到返回结果类型上细微的差别

    • vlaues -
      • 单条记录 - <class 'dict'>
      • 多条记录 - <class 'django.db.models.query.QuerySet'>
    • vlaues_list -
      • 单条记录 - <class 'tuple'>
      • 多条记录 - <class 'django.db.models.query.QuerySet'>
  • 相关阅读:
    【BZOJ 4151 The Cave】
    【POJ 3080 Blue Jeans】
    【ZBH选讲·树变环】
    【ZBH选讲·拍照】
    【ZBH选讲·模数和】
    【CF Edu 28 C. Four Segments】
    【CF Edu 28 A. Curriculum Vitae】
    【CF Edu 28 B. Math Show】
    【CF Round 439 E. The Untended Antiquity】
    【CF Round 439 C. The Intriguing Obsession】
  • 原文地址:https://www.cnblogs.com/yspass/p/10081864.html
Copyright © 2011-2022 走看看