笔记如下

一.QuerySet
QuerySet是什么?
类似列表里边存着对象
只和ORM有关系
from app01.models import Book

def qDemo(request):
    book_list = Book.objects.all()
    # 支持切片
    print(book_list[1:])
    # 支持遍历
    for book in book_list:
        print(book.id)
    # 惰性查询 (保证内存空间最大使用率)

    f = open('a.txt', 'r')
    for line in f.readlines():  # 一下全拿出来,内存可能装不下
        pass

    for line in f:  # 惰性求值,f充当迭代器对象,用一行取一行
        pass

    book_list = Book.objects.all()
    # 不用book_list。就不会执行sql语句,不走数据库。

    # 需要走数据库的操作(取决于用没用book_list里面的数据,即计算查询集)
    for book in book_list:  # 此时用到了就会走数据库去查询。
        print(book)

    print(book_list[1])

    if book_list:
        print('hello')

    ret = list(book_list)

    # 切片,序列化,缓存 ,list

    # 缓存机制
    book_list = Book.objects.all()

    for book in book_list:
        print(book.id)
    for book in book_list:
        print(book.id)

    # 打印两次,只走了一次数据库,查询一次就把结果放到book_list里缓存起来了

    book_list = Book.objects.all()

    for book in book_list:
        print(book.id)
    Book.objects.create(title='python')
    for book in book_list:
        print(book.id)

    # 两次用的都是第一次查询缓存的结果,新增的没有被用到。

    #  两次都去数据库查询
    for book in Book.objects.all():
        print(book)
    for book in Book.objects.all():
        print(book)

    # 优化QuerySet的缓存
    book_list = Book.objects.all()
    if book_list:  # 全查询出来,select * from db;
        print('里面有记录')

    # 上面我只想判断有没有,而他全查出来了
    if book_list.exists():  # 只取一条;
        print('里面有记录')

    # 缓存没问题,但是要限制量,当量非常大的时候怎么办?
    # 迭代器!
    book_list = Book.objects.all().iterator()
    print(type(book_list))  # <class 'generator'>

    for book in book_list:
        print(book)

    # 第二次打印的是空,因为生成器也是迭代器,取出一个少一个。

二.中介模型

class            student            courst

id name          id  name           id  name
1    s1          1    lcg            1   Go
                 2    ming           2   Python
s_c
id student_id  course_id
1       1         1
2       2         1
3       2         2
处理类似的多对多关系时,使用标准的ManyToManyField可以描述关系。
但是,有时你可能需要关联数据(score)到两个模型之间的关系上。
s_c
id student_id  course_id  score
1       1         1        80
2       2         1        90
3       2         2        100

ORM中介模型:

class Student(models.Model):
    name=...
class Course(models.Model):
    name=...
    students=models.ManyToMany("Student",through="Course_students")
    # through告诉ORM我自己去创建第三张表,不必给我自动创建,students这个字段我也用。
class Course_students(models.Model):
    student_id=mdoels.ForeignKey("Student")
    course_id=mdoels.ForeignKey("Course")
    score=models.IntegerFiled()

  

总结:

QuerySet

惰性查询,缓存机制

查询优化:

if book_list.exists():
  pass

缓存优化:book_list = Book.objects.all().iterator()

中介模型 多对多关系中,自己创建第三张表,并且保留关联字段(可使用ORM操作又扩展了第三张表的字段)

students=models.ManyToMany("Student",through="Course_students")

注意:
添加操作:
给python课程添加两个学生aa,bb
if 不是中介模型:
c=Course(name="python")
c.students.add('aa','bb')

if 使用中介模型:
Course_students实例对象的方法创建多对多关系

Django QuerySet和中介模型的更多相关文章

  1. Django进阶之QuerySet和中介模型

    QuerySet QuerySet是查询集,就是传到服务器上的url里面的查询内容.其形态类似于Python的列表,列表中的元素是QuerySet对象.支持大部分列表的内置方法. 可切片 QueryS ...

  2. model进阶(queryset,中介模型,查询优化,extra)

    queryset 方法 ############# 可切片 def queryTest(request): ret = models.Atricle.objects.all() 数据库查询 print ...

  3. Django【第26篇】:中介模型以及优化查询以及CBV模式

    中介模型以及优化查询以及CBV模式 一.中介模型:多对多添加的时候用到中介模型 自己创建的第三张表就属于是中介模型 class Article(models.Model): ''' 文章表 ''' t ...

  4. Django - 回顾(2)- 中介模型

    一.中介模型 我们之前学习图书管理系统时,设计了Publish.Book.Author.AuthorDetail这样几张表,其中Book表和Author表是多对多关系,处理类似这样简单的多对多关系时, ...

  5. Django框架 之 ORM中介模型

    Django框架 之 ORM中介模型 中介模型 处理类似搭配 pizza 和 topping 这样简单的多对多关系时,使用标准的ManyToManyField  就可以了.但是,有时你可能需要关联数据 ...

  6. django中介模型,CBV模型,及logging日志配制

    1.中介模型 中介模型,这个是在我们创建表格时,多对多添加的时候应用到的,通过制定ManyToManyField字段中的through参数来定义,为两者的关系新建一个中介class 为什么会产生这个中 ...

  7. 中介模型以及优化查询以及CBV模式

    一.中介模型:多对多添加的时候用到中介模型 自己创建的第三张表就属于是中介模型 class Article(models.Model): ''' 文章表 ''' title = models.Char ...

  8. 中介模型,cbv视图,和查询优化

    中介模型: 处理类似搭配 pizza 和 topping 这样简单的多对多关系时,使用标准的ManyToManyField  就可以了.但是,有时你可能需要关联数据到两个模型之间的关系上. 例如,有这 ...

  9. Django-model进阶(中介模型,查询优化,extra,整体插入)

    QuerySet 可切片 使用Python 的切片语法来限制查询集记录的数目 .它等同于SQL 的LIMIT 和OFFSET 子句. ? 1 >>> Entry.objects.al ...

随机推荐

  1. sql server中如何将两个字段数据合并成一个字段显示(字段与字段添加特殊符号)

    之前,我在做统计数据时,需要一个字段显示某月的订单数量和订单金额,要求组合成一个字段,用括号组合. 统计出来的结果大概是这样的,首先我们来创建一些模拟数据 ---创建订单表--- create tab ...

  2. WEB-ERROR-PAGE

    首先需要在Web.xml文件中配置如下标签:     <error-page>        <error-code>404 </error-code>       ...

  3. learning shell built-in variables (1)

    Shell built-in variables [Purpose]        Learning shell built-in variables, example $0,$1,$2,$3,$#, ...

  4. C/S架构系统自动化测试入门

    所谓C/S架构即Client/Server(客户端/服务器架构).虽然近年来C/S架构产品越来越少,大有被B/S(Browser/Server 浏览器/服务器)架构超越的趋势,但C/S还是有B/S不可 ...

  5. POJ 3352 Road Construction 双联通分量 难度:1

    http://poj.org/problem?id=3352 有重边的话重边就不被包含在双连通里了 割点不一定连着割边,因为这个图不一定是点连通,所以可能出现反而多增加了双连通分量数的可能 必须要用割 ...

  6. Integer封装类的相关知识

    java中,在一些情况下会有自动装箱与自动拆箱. 自动拆箱/装箱是在编译期,依据代码的语法,决定是否进行拆箱和装箱动作.装箱过程:把基本类型用它们对应的包装类型进行包装,使基本类型具有对象特征.拆箱过 ...

  7. ESET Smart Security 6 – 免费60天(SG)

    ESS 60天 - 活动消息来自新加坡脸谱https://www.facebook.com/esetsingapore/app_190322544333196IP限制Sg,suiss提供个在线代理ht ...

  8. Locust 其他协议

    Locust 是基于HTTP作为主要目标构建的,但是他同样可以扩展其他的协议,接受请求与获得返回.在编写的客户端的时候,我们就要使用到最常使用的 request_success 和 request_f ...

  9. 升级 macOS Mojave 后部分软件 (如 VS Code) 字体变虚的解决方法

    目前有些朋友的设备可能还是“非 Retina” 显示器,那这样如果升级到 Mojave 后你会发现文字不清晰了,这是因为 Mojave 默认关闭了文字次像素渲染字体,你需要在终端里执行: defaul ...

  10. linux-推荐两款好用的录屏软件

    前言 测试程序过程中需要看运行效果如何,可以使用录屏软件进行回放. 软件安装 添加源:sudo add-apt-repository ppa:maarten-baert/simplescreenrec ...