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'>
  • 相关阅读:
    套用JQuery EasyUI列表显示数据、分页、查询
    Linux 进程间通信 信号
    Linux socket编程
    Linux字符设备驱动注册流程
    Linux杂项设备与字符设备
    Linux并发控制解决竞态的一种操作>原子操作
    Linux 进程间通信 管道通信
    Linux串口编程
    博客开通啦!
    实现Windows Phone 8多媒体:视频
  • 原文地址:https://www.cnblogs.com/yspass/p/10081864.html
Copyright © 2011-2022 走看看