django.db.models.query.QuerySet

QuerySet特点:

1、可迭代

2、可切片

查询相关API

1、get(**kwargs):返回与所给的筛选条件相匹配的对象,返回结果有且只有一个。如果符合筛选条件的对象超过一个,就会抛出MultipleObjectsReturned异常,如果没有找到符合筛选条件的对象,就会抛出DoesNotExist异常。

2、all():查询所有结果的对象集。

3、filter(**kwargs):它包含了与所给的筛选条件相匹配的对象集。

4、exclude(**kwargs):它包含哪些与所给筛选条件不匹配的对象集。

5、order_by(*fields):对查询结果排序

6、reverse():对查询结果反向排序

7、distinct():对返回结果剔除重复记录

8、values(*fields):返回一个ValuesQuerySet,一个特殊的QuerySet,运行后得到的并不是一系列的model的实例化对象,而是一个可迭代的字典序列。

9、values_list(*fields):它与values()非常相似,只不过后者返回的结果是字典序列,而values_list()返回的是元祖序列。

10、count():返回数据库中匹配查询QuerySet的对象数量

11、first():返回第一条记录,等价于[:1][0]

12、last():返回最后一条记录,等价于[::-1][0]

13、exists():如果QuerySet包含有数量,就返回True否则就返回False。

...

更多详见:https://docs.djangoproject.com/en/1.10/ref/models/querysets/

实例:

初始化数据:

INSERT INTO `hello_author` VALUES ('', '叶良辰');
INSERT INTO `hello_author` VALUES ('', '潘晓明');
INSERT INTO `hello_author` VALUES ('', '陈吉');
INSERT INTO `hello_author` VALUES ('', '张晓菲');
INSERT INTO `hello_author` VALUES ('', '兰洋');
INSERT INTO `hello_author` VALUES ('', '温银福');
INSERT INTO `hello_author` VALUES ('', '何月顺');
INSERT INTO `hello_author` VALUES ('', '黄文高'); INSERT INTO `hello_authordetail` VALUES ('', '', '333@qq.com', '北京XX', '1988-01-02', '');
INSERT INTO `hello_authordetail` VALUES ('', '', '333@qq.com', '广州XX', '1987-01-02', '');
INSERT INTO `hello_authordetail` VALUES ('', '', '333@qq.com', '上海XX', '1986-01-02', '');
INSERT INTO `hello_authordetail` VALUES ('', '', '333@qq.com', '广州XX', '1985-01-02', '');
INSERT INTO `hello_authordetail` VALUES ('', '', '333@qq.com', '杭州XX', '1984-01-02', '');
INSERT INTO `hello_authordetail` VALUES ('', '', '333@qq.com', '广西XX', '1983-01-02', ''); INSERT INTO `hello_publisher` VALUES ('', '电子工业出版社', '北京朝阳区', '北京', '北京', '中国', 'http://www.phei.com.cn');
INSERT INTO `hello_publisher` VALUES ('', '机械工业出版社', '广州天河区', '广州', '广东', '中国', 'http://www.hzbook.com');
INSERT INTO `hello_publisher` VALUES ('', '人民邮电出版社', '广州番禺区', '广州', '广东', '中国', 'http://ptpress.com.cn'); INSERT INTO `hello_book` VALUES ('', '锋利的jQuery', '2017-03-01', '10.00', '');
INSERT INTO `hello_book` VALUES ('', '移动App测试实战', '2016-08-01', '25.00', '');
INSERT INTO `hello_book` VALUES ('', '持续集成实践', '2015-10-14', '50.00', '');
INSERT INTO `hello_book` VALUES ('', '深入性能测试', '2017-03-02', '100.00', ''); INSERT INTO `hello_book_authors` VALUES ('', '', '');
INSERT INTO `hello_book_authors` VALUES ('', '', '');
INSERT INTO `hello_book_authors` VALUES ('', '', '');
INSERT INTO `hello_book_authors` VALUES ('', '', '');
INSERT INTO `hello_book_authors` VALUES ('', '', '');
INSERT INTO `hello_book_authors` VALUES ('', '', '');
INSERT INTO `hello_book_authors` VALUES ('', '', '');
INSERT INTO `hello_book_authors` VALUES ('', '', '');
INSERT INTO `hello_book_authors` VALUES ('', '', '');

初始化SQL

1、查询id为1的书籍信息,并只显示书籍名称和出版日期;

>>> Book.objects.filter(id=1).values('title','publication_date')

>>> Book.objects.filter(id=1).values_list('title','publication_date')

2、查询所有出版社信息,并按id降序排列,并尝试使用reverse方法进行反向排序;

>>> Publisher.objects.order_by('-id')

>>> Publisher.objects.order_by('id').reverse()

3、查询出版社所在的城市信息,城市信息不要重复;

>>> Publisher.objects.all().values('city').distinct()

4、查询城市是北京的出版社,尝试使用exclude方法

>>> Publisher.objects.filter(city='北京')

5、查询男作者的数量

>>> AuthorDetail.objects.filter(sex=0).count()

***微信扫一扫,关注“python测试开发圈”,了解更多测试教程!***

最新文章

  1. Unity Shaders 第一个默认程序分析
  2. BZOJ 1036: [ZJOI2008]树的统计Count
  3. HDU 5875 Function -2016 ICPC 大连赛区网络赛
  4. atitit.信息安全的控制总结o7
  5. Android拼图游戏
  6. Unity的使用
  7. Mongodb操作总结
  8. 如何利用.Net内置类,解析未知复杂Json对象
  9. JS 实现banner图的滚动和选择效果
  10. Java中从键盘输入的三种方法
  11. 全国省市县区域信息最新数据库脚本(mysql版本)
  12. 探究 CSS 混合模式\滤镜导致 CSS 3D 失效问题
  13. 全局鼠标钩子:WH_MOUSE_LL, 在【 win 10 上网本】上因为太卡,运行中丢失全局鼠标钩子
  14. JMeter压测基础(三)——Mysql数据库
  15. linux下python3.5环境搭建
  16. Hadoop介绍-1.基本原理
  17. Extjs实现Grid表格显示【一】
  18. pytorch 绘制训练曲线;服务器端训练,本地浏览器显示,本地打不开;tensorboard端口被占
  19. Python之路----列表推导式和生成器的表达式
  20. datagrid在MVC中的运用09-实现排序

热门文章

  1. JavaScript四种数值取整方法
  2. Numpy常用操作方法
  3. DRF(4) - 认证、权限组件
  4. Andrew Ng机器学习总结(自用)
  5. Unity3d依赖于平台的编译
  6. JPA 对象关系映射之关联关系映射策略
  7. 使用 10046 查看执行计划并读懂 trace 文件
  8. GIT学习笔记(5):变基
  9. JSP SERVLET 基础知识
  10. NGUI如何使用汉字