Django class-based view的QuerySet三个层次以及函数调用路线图

本文介绍了Django Class-Based View中QuerySet的三个层次:显示所有对象、根据条件过滤和使用get_object()获取单个对象。详细阐述了get_queryset()和get_object()的使用及调用顺序,并解析了视图类内部的方法调用流程,如dispatch()、get()等。
摘要由CSDN通过智能技术生成

QuerySet的三个层次:

第一个:

显示所有的objects:

class ExampleView(ListView):

model = Example

第二个:

显示满足查询条件的子集:

class ExampleView(ListView):

queryset = Example.objects.filter(fieldname='something')

或者用get_queryset()

class ExampleView(ListView):

def get_queryset(self):

return Example.objects.filter(...)

第三个:get_object()

get_object()返回单个的object。如果有了queryset,则将其作为object数据源,否则,就会调用get_queryset()获取数据源。get_object()首先搜寻视图中的pk_url_kwarg参数,如果找到,就根据其进行主键查找(primary-key based)。如果没有pk_url_kwarg,就搜寻slug_url_kwarg参数,然后针对slug_field进行slug查询。如果query_pk_and_slug为True,则进行主键和slug的组合查询。


视图类中方法的调用顺序

dispatch()永远是第一个被调用的方

Django中,处理一对多(Many-to-Many)关系的新建和更新通常涉及到两个模型之间的关联表。例如,如果你有两个模型`Author`和`Book`,作者可以有多本书,书也可以有多个作者,这就是一对多关系。以下是使用`QuerySet`在Django中进行操作的一般步骤: 1. **新建数据**: - 要添加一个新的作者及其关联的书籍,你可以先创建作者实例,然后通过属性访问其`books`关联集合: ```python author = Author.objects.create(name="John Doe") book = Book(title="Book Title") # 将新书添加到作者的书籍列表 author.books.add(book) ``` - 或者,如果`Book`有一个反向引用(`author_set`): ```python book.authors.add(author) ``` 2. **更新数据**: - 如果你想更新一个作者已有的书籍,例如删除一本书或替换书籍列表,可以使用`remove()`或`clear()`方法: ```python # 删除某本书 author.books.remove(book) # 清空所有书籍 author.books.clear() # 或者添加新的书籍 author.books.add(Book(title="New Book")) ``` 3. **通过外键更新关联**: - 如果你想要更新书籍信息,并自动更新所有关联的作者,可以使用`save()`方法,因为它会触发数据库的级联更新规则: ```python book.title = "Renamed" book.save() # 这将会更新所有与book相关的author对象的title字段 ``` 记得在实际操作时,检查并处理可能出现的异常,比如试图删除最后一本书可能会导致错误。同时,确保你理解了你的数据模型结构以及它们之间的约束。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值