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

Django进阶-6-ORM正向与反向查找

学习 django 中的 orm 的时候,可以把一对多,多对多,分为正向和反向查找两种方式。...正向查找:ForeignKey 在 UserInfo 表中,如果从 UserInfo 表开始向其他的表进行查询,这个就是正向操作,反之如果从 UserType 表去查询其他的表这个就是反向操作。...一对多:models.ForeignKey(其他表) 多对多:models.ManyToManyField(其他表) 一对一:models.OneToOneField(其他表) ① 正向连表操作 所谓正、反向连表操作的认定无非是...Foreign_Key字段连表,反之没有Foreign_Key 字段就使用与其关联的 小写表名; 1对多:对象.外键.关联表字段,values(外键字段__关联表字段) 多对多:外键字段.all() ② 反向连表操作...通过value、value_list、fifter 方式反向跨表:小写表名__关联表字段 通过对象的形式反向跨表:小写表名_set().all() 应用场景: 一对多:当一张表中创建一行数据时,有一个单选的下拉框

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

Django之URL反向解析

1、反向解析的概述和来由 2、反向解析的示例 3、url分组的反向解析 1、反向解析的概述和来由 在Django中提供了关于URL的映射的解决方案,可以做两个方向的使用 1.普通解析过程:由客户端的浏览器发起一个...2、反向解析的示例 示例:登录成功跳转到index.html页面 在urls.py中 from django.conf.urls import url from django.contrib import...import render from django.shortcuts import reverse # 用于反向解析 from django.shortcuts import redirect #...# 后端views.py反向解析的使用 from django.shortcuts import render,HttpResponse,redirect,reverse url = reverse...的反向解析,例如 from django.conf.urls import url from django.contrib import admin from app01 import views urlpatterns

1.7K20

Django学习笔记之Django的url反向解析

0x00 URL反向解析和三种不同的反向解析方式 Django中提供了关于URL的映射的解决方案,可以做两个方向的使用: 1.普通解析过程:由客户端的浏览器发起一个url请求,Django根据URL解析...2.反向解析:通过一个视图的名字,再加上一些参数和值,逆向获取相应的URL。...Django提供了三种不同反向解析处理方式: 1.在模板templates中,使用url标记,如:{% url %} 2.在view中,使用django.core.urlresolvers.reverse...url(r'^articles/(\d{4})/$', 'news.views.year_archive'), #... ) 0x01 模板中的反向解析 <a href="{% url 'news.views.year_archive...()方法,然后原理是根据提供的视图和参数的值来逆向<em>查找</em>URLconf,匹配相应的url然后把值拿回来, # 最后,reverse()返回的值为:articles/2006/,这样就逆向的查出了需要的url

81610

Django 教程 --- Django 模型

Django模型简化了任务并将表组织到模型中。通常,每个模型都映射到单个数据库表。 本文围绕如何使用Django模型方便地将数据存储在数据库中展开。...此外,我们可以使用Django的管理面板来创建,更新,删除或检索模型的字段以及各种类似的操作。Django模型提供了简单性,一致性,版本控制和高级元数据处理。...模型的基础包括– 每个模型都是一个子类的Python类django.db.models.Model。 模型的每个属性代表一个数据库字段。...使用Django模型 要使用Django模型,需要在其中运行一个项目和一个应用程序。启动应用程序后,可以在app / models.py中创建模型。...Django模型中的内置字段验证是所有Django字段预定义的默认验证。

2.1K10

Linux 下 grep 显示前后几行信息, 递归查找, 反向查找

此时,可以使用如下命令: grep test *file 结果如下所示: $ grep test test* #查找前缀有“test”的文件包含“test”字符串的文件 testfile1:This...#列出testfile_2 文件中包含test字符的行 testfile_2:Linux test #列出testfile_2 文件中包含test字符的行 2、以递归的方式查找符合条件的文件。...Rather than /etc/acpi/events/thinkpad-cmos:action=/usr/sbin/thinkpad-keys--update 3、反向查找。...前面各个例子是查找并打印出符合条件的行,通过"-v"参数可以打印出不符合条件行的内容。...查找文件名中包含 test 的文件中不包含test 的行,此时,使用的命令为: grep -v test *test* 结果如下所示: $ grep-v test* #查找文件名中包含test 的文件中不包含

4.5K40

django模型

每个模型对 应数据库中唯一的一张表 如何编写模型 模型:每个模型都用一个类表示,该类继承自django.db.models.Model。...字段选项——unique 如果该值设置为True,这个字段的值在整张表中必须是唯一的 模型meta选项 使用内部的class Meta 定义模型的元数据,例如: from django.db import...来表示随机排序 编写服务器模型 数据库迁移 迁移是Django用于同步你的发生改变的模型(添加一个字段,删除一个模型,等等)到你的 数据库 迁移命令 makemigrations, 负责基于你的模型修改创建一个新的迁移...这个异常是正在查询的模型类的一个属性 —— 所以在上面的代码中, 如果没有主键为1 的Entry 对象,Django 将引发一个Entry.DoesNotExist。...如果有多条记录满足get() 的查询条件,Django 也将报错。这种情况将引发 MultipleObjectsReturned,它同样是模型类自身的一个属性。

3.1K20

django之路由分组,反向解析,有名

通过名字反向推导出页面文件,类似于字典 前端反向解析 {% url 'add' %} # {% url '放urls.py中路由与视图函数的name的值' %} ? ?...无名分组的反向解析 前端反向解析 {% url 'add' 1 %} # {% url '放urls.py中路由与视图函数的name的值' %} ?...(传无名)',name=('反向') def xxx (request 无名) reverse('反向',args(无名,)) render(request,'.html',{'无名':...import url from app02 import views urlpatterns = [ url(r'^index/',views.index) ] 如果两个app下起了相同的名字,那么反向解析不支持自动查找应用前缀...的区别(了解) 1.0里面的url对应django2.0里面re_path django2.0里面的path第一个是精准匹配(你怎么写的,我就怎么匹配) django1.0版本中匹配到的参数都是字符串类型

1.6K10

Django url 反向解析 和 命令空间

第二种方式叫做反向解析URL、反向URL匹配、反向URL查询或者简单的URL反查。...在更高层的与处理Django 模型实例相关的代码中:使用get_absolute_url() 方法。...反查带命名空间的URL¶ 当解析一个带命名空间的URL(例如'polls:index')时,Django 将切分名称为多个部分,然后按下面的步骤查找: 首先,Django 查找匹配的应用命名空间(在这个例子中为...如果有一个当前应用被定义,Django查找并返回那个实例的URL 解析器。当前应用可以通过请求上的一个属性指定。...如果提供的命名空间与第1步中的应用命名空间 不匹配,Django 将尝试直接将此命名空间作为一个实例命名空间查找

2.4K30

django-7-django模型系统

>> https://docs.djangoproject.com/en/2.1/ref/models/fields/#field-types  InterField  CharFiled...2.1/ref/models/fields/#field-options primary_key auto_dreated unique指定是否为唯一 auto_now >>  通过模型类上的管理器来构造... 模型类上的管理器(class.objects)  queryset (惰性,,没有操作数据库)表示数据库中对象的集合,等同于select 语句   query 获取mysql 语句  first()...*kwargs) 根据给定的条件获取过滤后的queryset,多个条件用','连接  exclude(**kwargs) 作用和filter相反,去除不符合条件的对象  多条件的or连接  from django.db.models... gt 大于  gte 大于等于  lt  lte  startswith  istartswith  endswith  iendswith  isnull True False  聚合  django.db.models

78210
领券