首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

django-ForeignKey,OneToOneField,ManyToManyField

进入到django自带related.py中,可以看到 1.ForeignKey 初始化参数有: to, on_delete, related_name=None, related_query_name...models.Model): book = models.ForeignKey(to='Author',on_delete=models.CASCADE,to_field='id') to:被关联表名称...on_delete:删除带有外键信息时,定义了删除操作: CASCADE:删除作者信息一并删除作者名下所有书信息; PROTECT:删除作者信息时,采取保护机制,抛出错误:即不删除Books...内容; SET_NULL:只有当null=True才将关联内容置空; SET_DEFAULT:设置为默认值; SET( ):括号里可以是函数,设置为自己定义东西; DO_NOTHING:字面的意思...,啥也不干,你删除你干我毛线关系; to_field:被关联字段,一般是主键,也可以是值唯一字段 2.OneToOne 初始化参数有: to, on_delete, to_field=None,

68530
您找到你想要的搜索结果了吗?
是的
没有找到

Django:使用filterpk进行多值查询操作

由于想要做收藏夹功能,所以希望能够一次性查询出所有id对象,查看文档,找到了如下方法 pk是primary key缩写,顾名思义pk_in就是primary key在某一个范围内,具体操作(以自带...User为例): User.objects.filter(pk__in=[1,2,3]) 这样就可以去除id为1,2,3User对象了,很方便 注意是两个下划线 另外,还要pk__gt和pl_lt...pk__lt=10) 意味着将要得到pk小于10对象 补充知识:Django 比较同一个model中两个字段,进行条件过滤 django orm中怎么样比较同一个模型中两个字段来过滤记录呢?...select *from contracts where contract_stop_time<end_time 这里要是用db模块中F 库才行 F object from django.db.models...以上这篇Django:使用filterpk进行多值查询操作就是小编分享给大家全部内容了,希望能给大家一个参考。

1.5K30

Django笔记(九)DjangoORM,查询数据方法

建表 需求(1) 需求(2) 总结 value()函数,获取列表 value()函数,获取元组 总结 建表 目前有两个表,一个用户表,一个用户类型表,一个用户对应一类型,但是一个类型下面有好多用户...外键是在用户表里面 需求(1) 根据查询出来用户,获取他用户类型,这个就是多表查询,实现代码是 先查询出用户,直接根据外键字段获取他用户类型 需求(2) 根据一个用户类型,查询他下面的所有的用户...其实有一个隐含字段,写法是 总结 value()函数,获取列表 value()函数,获取元组 总结 以上方法 字典和元组是不可以跨表查询 以下写法是可以跨表

85520

django 模型关系

多对一关系 多对多关系 一对一关系 多对一 django使用django.db.models.ForeignKey 定义多对一关系 ForeignKey需要一个位置参数来指定本Model关联Model...正向查询( ForeignKey 所在模型查询关联模型) car = Car.objects.get(pk=2) car.manufacturer #返回一条Manufacturer 对象 反向查询...默认情况下,这个管理器名字为foo_set,其中foo 是源模型小写名称。该管理器返回查询集可以用上一节提到方式进行过滤和操作。...clear() #从关联对象集中删除所有的对象 多对多 要实现多对多,就要使用django.db.models.ManyToManyField类,和ForeignKey一样,它也有一个位置参数,用来指定和它关联...(Group) 建议以被关联模型名称复数形式做为 ManyToManyField 名字 在哪个模型中设置 ManyToManyField 并不重要,在两个模型中任选一个即可——不要在两个模型中都设置

1.4K30

DjangoORM操作-查询数据

数据库查询需要使用管理器对象进行 通过mymodel.objects管理器方法调用查询对象 方法 说明 all() 查询全部记录,返回QuerySet查询对象 get() 查询符合条件单一记录 filter...() 查询符合条件多条记录 exclude() 查询符合条件外全部记录 all()方法 ---- 使用方法:Asset.objects.all() from monitor.models import...,内部存放是元组 会将查询出来数据封装到元组中,在封装到查询集合QuerySet中 >>> a = Asset.objects.values_list("create_date") >>> a...("title").order_by('-price') >>> print(a.query) # 可以使用这种方式查看发送给MySQL查询语句 filter() ---- 用法:Asset.objects.filter...="admin",system="Linux") for i in info: print("查询结果",i.create_date) 查询谓词 定义:做更灵活条件查询时候需要使用查询谓词 每一个查询谓词是一个独立查询功能

80520

Django 模型查询2.3

offset子句 注意:不支持负数索引 使用下标后返回一个新查询集,不会立即执行查询 如果获取一个对象,直接使用[0],等同于[0:1].get(),但是如果没有数据,[0]引发IndexError异常...,[0:1].get()引发DoesNotExist异常 查询缓存 每个查询集都包含一个缓存来最小化对数据库访问 在新建查询集中,缓存为空,首次对查询集求值时,会发生数据库查询django会将查询结果存在查询缓存中...,但是如果这部分不在缓存中,那么接下来查询返回记录将不会被缓存,这意味着使用索引来限制查询集将不会填充缓存,如果这部分数据已经被缓存,则直接使用缓存中数据 字段查询 实现where子名,作为方法filter...')) django支持对F()对象使用算数运算 list.filter(bread__gte=F('bcommet') * 2) F()对象中还可以写作“模型类__列名”进行关联查询 list.filter...,会合并为And进行 需要进行or查询使用Q()对象 Q对象(django.db.models.Q)用于封装一组关键字参数,这些关键字参数与“比较运算符”中相同 from django.db.models

2.3K20

八、Django分组查询

分组查询、F查询和Q查询 分组查询 统计每个出版社出版书籍平均价格 第一种方式 obj = models.Book.objects.values('publishs_id').annotate(...5,decimal_places=2) #decimal(16,2) publishs=models.ForeignKey(to="Publish") authors=models.ManyToManyField...当一个操作符在两个Q 对象上使用时,它产生一个新Q 对象。 你可以组合& 和| 操作符以及使用括号进行分组来编写任意复杂Q 对象。...同时,Q 对象可以使用~ 操作符取反,这允许组合正常查询和取反(NOT) 查询: bookList=Book.objects.filter(Q(authors__name="yuan") & ~Q(publishDate...所有提供给查询函数参数(关键字参数或Q 对象)都将"AND”在一起。但是,如果出现Q 对象,它必须位于所有关键字参数前面。

63910

基于Django OneToOneField和ForeignKey区别详解

相反地,使用ForeignKey, 反向关联后会返回QuerySet。...relate_name, 则是对方类名小写_set [<Car2: Mazda ] 补充知识:Django ForeignKey,ManyToManyField和OneToOneField辨析 导引...通过一个限制对字段信息某一可能选项进行约束,可以通过字典,函数或者查询值来设置 related_name 可以指定关联类在本类中名称,通过这一参数可以用两个字段名引用同一个类,通过这个名称父类可以取得子类值...ManyToManyField类有两个经常使用参数:through和through_fields,通过这两个参数可以十分方便地建立中间项关联,如示例代码所示: from django.db import...ManyToManyField,其为这一字段建立一个单独属性,而是设定symmetrical属性为True,若期望使用此类迭代关系,可以手动设置其为False through 如上所示,用于设置中间项名字

2.3K20

第 03 篇:创建 Django 博客数据库模型

# 而对于标签来说,一篇文章可以有多个标签,同一个标签下也可能有多篇文章,所以我们使用 # ManyToManyField,表明这是多对多关联关系。...而对于标签来说,一篇文章可以有多个标签,同一个标签下也可能有多篇文章,所以我们使用 ManyToManyField,表明这是多对多关联关系。...当要查询文章属于哪一个分类时,只需要查看其对应分类 ID 是多少,然后根据这个分类 ID 就可以从分类数据库表中找到该分类数据。...反之,要查询某个分类下有哪些文章,只需要查看对应该分类 ID 文章有哪些即可。...详细示例[3]•django ManyToManyField 简介[4]•django ManyToManyField 详细示例[5] References [1] 关于字段类型介绍: https:/

55340

django 1.8 官方文档翻译:2-1-1 模型语法

Django 提供一套自动生成用于数据库访问API;详见执行查询。...中介模型有一些限制: 中介模型必须有且只有一个外键到源模型(上面例子中Group),或者你必须使用ManyToManyField.through_fields 显式指定Django 应该使用外键。...由于Django 查询语法工作方式,字段名称中连续下划线不能超过一个。...SQL 保留字例如join、where 和select,可以用作模型字段名,因为Django 会对底层SQL 查询语句中数据库表名和列名进行转义。 它根据你数据库引擎使用不同引用语法。...查询集始终返回请求模型 也就是说,没有办法让DJango查询Person对象时返回MyPerson对象。Person 对象查询集会返回相同类型对象。

4.9K20

Django 系列博客(十三)

to 设置要关联表 to_field 设置要关联字段 related_name 反向查询时,使用字段名,用于代替原反向查询'表名_set'。...to 设置要关联表 related_name 反向查询时,使用字段名,用于代替原反向查询'表名_set'。 symmetrical 仅用于多对多自关联时,指定内部是否创建反向操作字段。...("self", symmetrical=False) 此时,person 对象可以使用 person_set 属性进行反向查询。...through 在使用 ManyToManyField 字段时,Django 将自动生成一张表来管理多对多关联关系。...这样创建第三张表无法使用 set、add、remove、clear方法来管理对多多关系,需要通过第三张表来进行增、删、改,查询一样。

1.1K30
领券