本节是在上一小节的基础上继续完善我们的链表相关方法的编写,在本节中我们着重对如何获取链表中元素、查询元素以及修改元素进行学习。...一、获取元素 1.关于获取链表中元素的方法的分析 由于我们使用了虚拟头结点,而我们每次都需要从第一个真实节点开始,因此需要首先得到虚拟头结点的下一个节点是谁,然后在此基础上进行遍历工作,相关代码如下:...//获取链表的第index(0-based)个位置的元素 (实际不常用,练习用) public E get(int index) { //合法性判断 if...//获得链表的第一个元素 public E getFirst() { return get(0); } 3.获得链表的最后一个元素 对于该方法页是依靠在get()方法的。...e 由于我们使用了虚拟头结点,而我们每次都需要从第一个真实节点开始,因此需要首先得到虚拟头结点的下一个节点是谁,然后判断给定的元素值与链表中的元素值内容是否相等(equals()方法),若相等则返回true
多对一关系 多对多关系 一对一关系 多对一 django是使用django.db.models.ForeignKey 定义多对一关系 ForeignKey需要一个位置参数来指定本Model关联的Model...对象 反向查询( ForeignKey 指向的模型查询ForeignKey 所在的模型) 如果模型有一个ForeignKey,那么该ForeignKey 所指的模型实例可以通过一个管理器返回前一个有ForeignKey...默认情况下,这个管理器的名字为foo_set,其中foo 是源模型的小写名称。该管理器返回的查询集可以用上一节提到的方式进行过滤和操作。...#从关联的对象集中删除指定的模型对象。...clear() #从关联的对象集中删除所有的对象 多对多 要实现多对多,就要使用django.db.models.ManyToManyField类,和ForeignKey一样,它也有一个位置参数,用来指定和它关联的
distinct(): 从返回结果中剔除重复纪录(如果你查询跨越多个表,可能在计算QuerySet时得到重复的结果。...方法 create() 创建一个新的对象,保存对象,并将它添加到关联对象集之中,返回新创建的对象。...对象添加到关联对象集中。...>>> book_obj = models.Book.objects.first() >>> book_obj.authors.set([2, 3]) remove() 从关联对象集中移除执行的model...对象 >>> book_obj = models.Book.objects.first() >>> book_obj.authors.remove(3) clear() 从关联对象集中移除一切对象。
Django Form类定义中有一个 ModelChoiceField 对应的是Model 的外键,queryset 是返回一个查询集对象 例如,我有一个Form class BookForm(forms.Form...但是我想要传递books的id,就出现了问题。我们可以如下解决。...1、重写init方法并接受新的关键字 def __init__(self,*args,**kwargs): id = kwargs.pop('id',None) super(BookForm...BookForm() form.fields['books'].queryset = Books.objects.filter(id=1).all() 如果要设置默认值可以通过{initial={'id':1}的方法进行
在 Django 中,你可以使用单行查询来获取关联模型的数据。...这通常涉及使用查询集的 select_related 或 prefetch_related 方法,这两个方法允许你在一次数据库查询中获取关联模型的数据,而不是分开的多个查询。...下面是一些示例:1、问题背景在 Django 中,我们经常需要查询关联模型的数据。传统的方法是使用外键关系来获取关联模型的数据,这需要进行两次数据库查询。...为了提高效率,我们可以使用单行查询来获取关联模型的数据。...你可以根据自己的需求选择合适的方法。使用这些方法之一,我们可以在单行代码中获取关联模型的数据。这些方法可以帮助你优化数据库查询并减少不必要的查询次数,提高 Django 应用程序的性能。
你可以将过滤器保持一整天,直到查询集 需要求值时,Django 才会真正运行这个查询。...) # hits database if判断的时候也会执行,if queryResult:pass 一般来说,只有在“请求”查询集 的结果时才会到数据库中去获取它们。...理解它是如何工作的将让你编写最高效的代码。叫做queryset缓存空间 在一个新创建的查询集中,缓存为空。...首次对查询集进行求值 —— 同时发生数据库查询 ——Django 将保存查询的结果到查询集(非简单查询的查询结果,简单查询往下看。)...简单说,在对QuerySet使用select_related()函数后,Django会获取相应外键对应的对象,从而在之后需要的时候不必再查询数据库了。
通常,查询集 的切片返回一个新的查询集 —— 它不会执行查询。...你可以将过滤器保持一整天,直到查询集 需要求值时,Django 才会真正运行这个查询。 ?...在一个新创建的查询集中,缓存为空。首次对查询集进行求值 —— 同时发生数据库查询 ——Django 将保存查询的结果到查询集的缓存中并返回明确请求的结果(例如,如果正在迭代查询集,则返回下一个结果)。...例如,重复获取查询集对象中一个特定的索引将每次都查询数据库: 1 2 3 >>> queryset = Entry.objects.all() >>> print queryset[5] # Queries...简单说,在对QuerySet使用select_related()函数后,Django会获取相应外键对应的对象,从而在之后需要的时候不必再查询数据库了。
要求 修改数据库 Django shell 数据级联(一对多) 元信息 定义字段 模型过滤 创建对象4种方式 查询集 过滤器 获取单个对象 字段查询 时间 聚合函数 跨关系查询 F对象 Q对象...概念:查询集表示从数据库获取的对象集合,查询集可以有多个过滤器。.../缓存集 查询集的缓存:每个查询集都包含一个缓存,来最小化对数据库的访问 在新建的查询集中,缓存首次为空,第一次对查询集求值,会发生数据缓存,django会将查询出来的数据做 一个缓存,并返回查询结果...,以后的查询直接使用查询集的缓存。...- 都不会真正的去查询数据库 - 懒查询 - 只有我们在迭代结果集,或者获取单个对象属性的时候,它才会去查询数据 - 为了优化我们结果和查询 获取单个对象:
从数据库中查询出来的结果一般是一个集合,这个集合叫做 QuerySet。...dates() 根据日期获取查询集 datetimes() 根据时间获取查询集 none() 创建空的查询集 all() 获取所有的对象 union() 并集 intersection...如要获取QuerySet中最后五个元素,可以这样做: my_queryset.reverse()[:5] 这与Python直接使用负索引有点不一样。 Django不支持负索引,只能曲线救国。...当最初获取数据时不知道是否需要这些特定字段的情况下,如果正在使用查询集的结果,可以告诉Django不要从数据库中检索它们。...如果未提供列表,则会返回查询集中的所有对象。
('JR', 'Junior'), ('SR', 'Senior'), ('GR', 'Graduate'), ) 每个元组中的第一个元素,是存储在数据库中的值;第二个元素是在管理界面或...把指定的模型对象添加到关联对象集中。 例如: ?...Django会明白新的 Entry对象blog 应该添加到b中。 remove(obj1[, obj2, ...]) 从关联对象集中移除执行的模型对象: ?...对于ForeignKey对象,这个方法仅在null=True时存在。 clear() 从关联对象集中移除一切对象。 ?...,首先调用clear()方法来解除关联集中一切已存在对象的关联。
获取对象 通过模型中的Manager构造一个QuertSet,来从你的数据库中获取对象。 QuerySet表示你数据库中取出来的一个对象的集合。...使用过滤器获取特定对象 all()方法返回的结果集中包含全部对象,但是更普遍的情况是你需要获取完整集合的一个子集。 要创建这样一个子集,需要精炼上面的结果集,增加一些过滤器作为条件。...过滤后的结果集是独立的 每次你筛选一个结果集,得到的都是全新的另一个结果集,它和之前的结果集之间没有任何绑定关系。每次筛选都会创建一个独立的结果集,可以被存储及反复使用。...对 QuerySet 求值就意味着 Django 会访问数据库。想了解对查询集何时求值,请查看 何时对查询集求值 (When QuerySets are evaluated)....Django 也提供反向获取关联对象的 API,就是由从被关联的对象得到其定义关系的主对象。
对查询结果排序 reverse() 对查询结果反向排序 distinct() 从返回结果中剔除重复记录 values_list(*field...根据日期获取查询集 datetimes() 根据时间获取查询集 none() 创建空的查询集 union() 并集 intersection...的学员集 3.annotate(): nnotate(args, *kwargs) 使用提供的聚合表达式查询对象。 ...如要获取QuerySet中最后五个元素,可以这样做: my_queryset.reverse()[:5] 这与Python直接使用负索引有点不一样。...distinct() Account.objects.filter(account_name__regex=val).oreder_by('balance') 使用reverse()方法可以反转结果集中的元素顺序
Django 的 ORM 是创建 SQL 去查询和操作数据库的一个 Python 式的方式。...ForeignKey ManyToManyField ForeignKey 操作 正向查找 对象查找(跨表) 语法: 对象.关联字段.字段 示例: 字段查找(跨表) 语法: 关联字段__字段...它存在于下面两种情况: 外键关联的反向查询 多对多关联 当 . 点后面的对象可能存在多个的时候就可以使用以下的方法。...方法: ① create() 创建一个新的对象,保存对象,并将它添加到关联对象集之中,返回新创建的对象。 ② add() 把指定的 model 对象加到关联对象集中。...添加对象 添加 id ③ set() 更新 model 对象的关联对象。 ④ remove() 从关联对象集中移除执行的 model 对象 ⑤ clear() 从关联对象集中移除一切对象。
distinct(): 从返回结果中剔除重复纪录(如果你查询跨越多个表,可能在计算QuerySet时得到重复的结果。...方法: create() 创建一个新的对象,保存对象,并将它添加到关联对象集之中,返回新创建的对象。...对象添加到关联对象集中。...()只能填对象,不能用id 从关联对象集中移除执行的model对象 >>> book_obj = models.Book.objects.first() >>> book_obj.authors.remove...(3) clear() 从关联对象集中移除一切对象。
Django 的 filter、exclude 等方法使得对数据库的查询很方便了。这在数据量较小的时候还不错,但如果数据量很大,或者查询条件比较复杂,那么查询效率就会很低。...如果我要对 QerySet 中每个元素都进行聚合计算、并且返回的仍然是 QuerySet ,那就要用到 annotate() 方法了。...annotate 翻译过来就是 注解 ,它的作用有点像给 QuerySet 中的每个元素临时贴上一个临时的字段,字段的值是分组聚合运算的结果。...比方说要给查询集中的每本书籍都增加一个字段,字段内容是外链到书籍的作者的数量: from django.db.models import Count q = Book.objects.annotate...'books__price')) s[0].min_price Decimal('12') s[0].max_price Decimal('44') 既然 annotate() 返回的是查询集
添加数据(添加外键) 一对多(外键 ForeignKey) 方式一: 传对象的形式,返回值的数据类型是对象,书籍对象 步骤: 获取出版社对象 给书籍的出版社属性 pulish 传出版社对象 '''test.py...获取作者对象的 id b. 获取书籍对象 c....book_obj.authors.set([3, 2]) book_obj.authors.set([author_obj1, author_obj2]) ORM 删除和清空数据 remove():从关联对象集中移除执行的模型对象...models.Book.objects.get(id=11) author_obj.book_set.remove(book_obj) return HttpResponse("ok") clear():从关联对象集中移除一切对象...(title="三国演义").first() book.authors.clear() 跨表查询 正向:外键字段在哪,去从该表的角度查另外的表,就是正向 反向:从没有外键表去查另外相关联的表,就是反向
~共 10 章,31 子模块数据库学习目标能够进行Django数据库配置掌握Django中模型类的定义掌握Django中的迁移命令的使用能够使用Django的ORM进行数据库的增删改查能够说明查询集QuerySet...查询所有员工信息,按照id从大到小进行排序。...切片操作得到另一个新的QuerySet注意:下标不能为负数二、查询集两大特性1....惰性查询创建查询集时不会访问数据库,操作查询集中的数据时才会访问;操作查询集指 下标、切片、迭代操作,与if合用 等# 得到查询集,不会访问数据库 query_set = Department.objects.all...缓存功能当遍历(迭代)访问查询集 所有数据,会缓存查询集所有数据,当再次操作该查询集中的数据时,将会使用缓存;# 创建查询集 query_set = Department.objects.all
领取专属 10元无门槛券
手把手带您无忧上云