作业1

创建单表Book表,要求字段:

1 主键 nid
2 书名 title
3 价格 price
4 出版日期 pubDate
5 出版社 publisher(普通字符串字段)

class Book(models.Model):
nid = models.AutoField(primary_key=True)
title = models.CharField(max_length=32)
price = models.DecimalField(max_digits=5, decimal_places=2)
publishDate = models.DateTimeField()
publisher = models.CharField(max_length=64)

作业2

添加多条记录后,

查询:

(1) 查询所有书籍的名称

Book.objects.all().values("title")
(2) 查询价格大于100的书籍名称以及价格 Book.objects.filter(price__gt=100).values("title","price")
(3) 查询2017年出版的所有以py开头的书籍名称 Book.objects.filter(pubDate__year="",title__startswith="py").values("title") (4) 查询价格为50,100或者150的所有书籍名称及其出版社名称 Book.objects.filter(price__in=[50,100,150]).values("title","pubDate")
(5) 查询所有主键大于2小于5书籍的价格(去重) Book.objects.filter(nid__gt=2,nid__lt=5).values("price").distinct()
(6) 查询所有人民出版社出版的书籍的价格(从高到低排序,去重) Book.objects.filter(publisher="人民出版社").values("price").order_by("-price").distinct()

作业3

models.py

class Book(models.Model):
nid = models.AutoField(primary_key=True)
title = models.CharField(max_length=32)
publishDate = models.DateField()
price = models.DecimalField(max_digits=5, decimal_places=2) read_num=models.IntegerField(default=0)
commnet_num=models.IntegerField(default=0)
poll_num=models.IntegerField(default=0) # publish:与当前书籍对象关联的的出版社对象,与Publish建立一对多的关系,外键字段建立在多的一方
publish=models.ForeignKey(to="Publish",to_field="id") # authors: 与当前书籍关联的所有作者的集合
# 与Author表建立多对多的关系,ManyToManyField可以建在两个模型中的任意一个,自动创建第三张表 authors=models.ManyToManyField(to="Author")
def __str__(self):
return self.title
class Author(models.Model):
name=models.CharField(max_length=32)
age=models.IntegerField() class AuthorDetail(models.Model):
tel=models.CharField(max_length=32)
email=models.CharField(max_length=32) #与Author建立一对一的关系
author=models.OneToOneField("Author") class Publish(models.Model):
name=models.CharField(max_length=32)
email=models.CharField(max_length=32) def __str__(self):
return self.name

models.py

基于图书管理系统的表关系与数据,进行如下查询
要求:1-5查询分别基于对象查询,双下划线查询,以及找到对应翻译的sql语句 1、查询人民出版社出版过的价格大于100的书籍的作者的email
Book.objects.filter(publish__name="人民出版社",price__gt=100).values("authors__authordetail__email")
2、查询alex出版过的所有书籍的名称以及书籍的出版社的名称
Book.objects.filter(authors__name="alex").values("title","publish__name")
3、查询2011年出版社过的所有书籍的作者名字以及出版社名称
Book.objects.filter(publishDate__year=2011).values("publish__name","authors__name")
4、查询住在沙河并且email以123开头的作者写过的所有书籍名称以及书籍的出版社名称
Author.objects.filter(authordetail__addr="沙河",authordetail__email__startswith="").values("book__title","book__publish__name")
5、查询年龄大于20岁的作者在哪些出版社出版过书籍
Publish.objects.filter(book__authors__age__gt=20).values("name)
6、查询每一个出版社的名称以及出版过的书籍个数
Publish.objects.all().annotate(c=Count("book__id")).values("name","c")
7、查询每一个作者的名字以及出版过的所有书籍的最高价格
Author.objects.all().annotate(m=Max("book__price")).values("name","m")
8、查询每一本书的名字,对应出版社名称以及作者的个数
Book.objects.all().annotate(c=Count("authors")).values("c","title","publish__name")

【django之orm小练习】的更多相关文章

  1. Django 源码小剖: Django 对象关系映射(ORM)

    引 从前面已经知道, 一个 request 的到来和一个对应 response 的返回的流程, 数据处理和数据库离不开. 我们也经常在 views.py 的函数定义中与数据库打交道. django O ...

  2. Django中ORM介绍和字段及其参数

    ORM介绍 ORM概念 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术. 简单的说,ORM是通过使用描述 ...

  3. ORM以及Django使用ORM创建表

    day61 2018-04-28 1. 内容回顾 1. HTTP协议消息的格式: 1. 请求(request) 请求方法 路径 HTTP/1.1\r\n k1:v1\r\n ...\r\n \r\n ...

  4. Django中ORM实际应用

    1. Django中ORM的使用 1. 手动新建一个数据库 2. 告诉Django连接哪个数据库 settings.py里面配置数据库连接信息: # 数据库相关的配置项 DATABASES = { ' ...

  5. Django之ORM操作

    Django之ORM操作 前言 Django框架功能齐全自带数据库操作功能,本文主要介绍Django的ORM框架 到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞: 创建数据库,设计 ...

  6. Django之ORM操作总结

    Django之ORM总结 表结构 from django.db import models # 一对多:班级与学生 # 多对多:班级与老师 # Create your models here. #创建 ...

  7. Django之ORM初始

    上一篇写了一个静态的登录验证. 实景情况网页的登录验证都是动态验证的,过程其实是从后端拿到储存的账户与密码来和前端的输入信息进行匹配校验的. 一.把项目拆分,来一个单独登录的包,放在Django项目下 ...

  8. Django中ORM介绍和字段及字段参数 Object Relational Mapping(ORM)

    Django中ORM介绍和字段及字段参数   Object Relational Mapping(ORM) ORM介绍 ORM概念 对象关系映射(Object Relational Mapping,简 ...

  9. Django的orm中get和filter的不同

    Django的orm框架对于业务复杂度不是很高的应用来说还是不错的,写起来很方面,用起来也简单.对于新手来说查询操作中最长用的两个方法get和filter有时候一不注意就会犯下一些小错误.那么今天就来 ...

随机推荐

  1. 线程池内的异步线程创建UI控件,造成UI线程卡死无响应的问题分析

    winform应用在使用一段时间后,切换到其他系统或者打开word.excel文档,再切换回winform应用时,系统有时出现不响应的现象.有时在锁屏后恢复桌面及应用时也发生此问题. 经微软支持确认, ...

  2. 基于ssh框架的highcharts前后台数据交互实例

    Highcharts 是一个用纯JavaScript编写的一个图表库, 能够很简单便捷的在web网站或是web应用程序添加有交互性的图表,并且免费提供给个人学习.个人网站和非商业用途使用.HighCh ...

  3. sqlserver 重置标识列

    重置标识信息:DBCC CHECKIDENT('表名', RESEED,0) 检查标识信息:DBCC CHECKIDENT('SysModule', NORESEED)

  4. 2016广东工业大学新生杯决赛网络同步赛暨全国新生邀请赛 题解&源码

    Problem A: pigofzhou的巧克力棒 Description 众所周知,pigofzhou有许多妹子.有一天,pigofzhou得到了一根巧克力棒,他想把这根巧克力棒分给他的妹子们.具体 ...

  5. 51 Nod 1057 N的阶乘【Java大数乱搞】

    1057 N的阶乘 基准时间限制:1 秒 空间限制:131072 KB 分值: 0 难度:基础题 输入N求N的阶乘的准确值.   Input 输入N(1 <= N <= 10000) Ou ...

  6. bzoj usaco 金组水题题解(2.5)

    bzoj 2197: [Usaco2011 Mar]Tree Decoration 树形dp..f[i]表示处理完以i为根的子树的最小时间. 因为一个点上可以挂无数个,所以在点i上挂东西的单位花费就是 ...

  7. bzoj usaco 金组水题题解(1)

    UPD:我真不是想骗访问量TAT..一开始没注意总长度写着写着网页崩了王仓(其实中午的时候就时常开始卡了= =)....损失了2h(幸好长一点的都单独开了一篇)....吓得赶紧分成两坨....TAT. ...

  8. kafka数据迁移实践

    欢迎大家前往云+社区,获取更多腾讯海量技术实践干货哦~ 作者:mikealzhou 本文重点介绍kafka的两类常见数据迁移方式:1.broker内部不同数据盘之间的分区数据迁移:2.不同broker ...

  9. 高性能网络编程(1)—accept建立连接‍(转载,作者:陶辉)

    编 写服务器时,许多程序员习惯于使用高层次的组件.中间件(例如OO(面向对象)层层封装过的开源组件),相比于服务器的运行效率而言,他们更关注程序开发 的效率,追求更快的完成项目功能点.希望应用代码完全 ...

  10. 好的Qt学习资料

    1.青春不老,奋斗不止!---CSDN博客地址http://blog.csdn.net/liang19890820: