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

Django学习-第七讲:django 中的常用字段、字段属性,外键和表关系、外键操作

模型中Meta配置 对于一些模型级别的配置。我们可以在模型中定义一个类,叫做Meta。然后在这个类中添加一些类属性来控制模型的作用。...外键和表关系 在MySQL中,表有两种引擎,一种是InnoDB,另外一种是myisam。如果使用的是InnoDB引擎,是支持外键约束的。外键的存在使得ORM框架在处理表关系的时候异常的强大。...即在article的实例中可以通过author属性来操作对应的User模型。这样使用起来非常的方便。...因此在底层,Django为Article表添加了一个属性名_id的字段(比如author的字段名称是author_id),这个字段是一个外键,记录着对应的作者的主键。...以后通过article.author访问的时候,实际上是先通过author_id找到对应的数据,然后再提取User表中的这条数据,形成一个模型。

4K30

django模型中有外键关系的表删除相关设置

0904自我总结 django模型中有外键关系的表删除相关设置 一.一对一 例如有Author、AuthorDetail两表 author = models.OneToOneField(to='Author...AuthorDetail表中:作者删除详情删除,详情删除作者保留 2)作者找详情用 外键related_name(detail),详情找作者用 外键字段(author) 3)db_constraint...Book表中(多的一方):出版社删除书外键不动,书删除没有任何影响 2)出版社找书用 外键related_name(books),书找出版社 外键字段(publish) 3)db_constraint...两者区别 models.SET关联表内容删了,关联的相关内容不会删除 models.CASCAD关联表内容删了,关联的相关内容会删除 db_constraint关系断开后,但是不影响联表查询 四.多对多关系...:出版社删除或书删除彼此不影响,但关系表一定级联删除 2)正向找 外键字段,反向找 外键字段related_name 3)db_constraint断开表关联,on_delete不存在(不设置,本质在第三张表中设置

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

    Django中基表的创建、外键字段属性简介、脏数据概念、子序列化

    db_table = 'xxx'指定该类的数据库表单名字。当然如果不指定也没关系,Django会自动默认的按照一定规则生成数据模型对应的数据库表名。...假设图书管理系统中书、出版社、作者、作者详细信息四张表之间的关系如下: """ 表关系 1)Book 和 Publish 一对多:外键在多的一方 Book 2)Book 和 Author 多对多:外键在查询频率高的一方...更合理) """ Django orm中外键字段属性详解 在建表之前我们对外键字段属性进行了解: 1)related_name在外键中设置外键反向查询的字段名:正向找字段名,反向找related_name...例子:部门没有了,部门员工里的部门字段改为未分组部门的id字段为NULL 注:多对多字段不能设置on_delete级联关系,如果要处理级联关系,需要手动明确关系,处理表关系中的多个外键 3)db_constraint...子序列化 Django中的子序列化的功能是:通过跨表查询数据然后对跨表查到的数据反序列化。

    4.3K30

    Django相关知识点回顾

    STATIC_URL --> 设置访问静态文件的url地址的前缀 django框架仅仅在DEBUG=True的模式下提供静态文件 7.客户端向服务器传递参数的途径 7.1通过url地址传递参数 url...request.META 7.5request对象的属性 Flask中request请求对象的属性 Django中request请求对象的属性 说明 args GET 查询字符串参数 form POST...class Meta: db_table = '' 定义外键属性: # 表中外键字段名格式: 外键属性_id> hbook = models.ForeignKey('BookInfo...() # 由多查1 多对象.外键属性 例:hero.hbook 2.通过模型类进行关联查询 # 查图书(一) 一类.objects.get|filter(多类名__字段__条件=值) 例:books =...BookInfo.objects.filter(heroinfo__hcomment__contains='八') # 查英雄(多) 多类.objects.filter(外键属性__字段__条件=值)

    10K51

    马哥金牌分享 | 十分钟学会用Django快速搭建一个blog

    但是在Django中,控制器接受用户输入的部分由框架自行处理,所以Django 里更关注的是模型(Model)、模板(Template)和视图(Views),称为MTV模式。...1.1 Django的结构模型 层次 职责 模型(Model)数据存取层 处理与数据相关的所有事务: 如何存取、如何验证有效性、包含哪些行为以及数据之间的关系等。...视图(View)表现层 处理与表相关的决定: 如何在页面或其他类型文档中进行显示。 模板(Template),业务逻辑层 存取模型及调取恰当模板的相关逻辑。模型与模板的桥梁。...文章和分类是什么关系? 文章和用户又是什么关系? 表之间是否需要外键进行关联?...4.5 启用django 访问admin后台 填充相关的信息 5.配置相关的模板 5.1 配置app的模板 1.把模板的index.html放到templates里面 2.模板的css,js,images

    2.4K51

    Django MVC概述和开发流程

    在Django中进行数据库开发一般需要三个步骤: 1.在应用的models.py中定义模型类 2.迁移 3.通过类和对象完成对数据库的CURD 1.定义模型类 首先添加了一个school_test应用,...设计学生类 学生类: 类名:StudentInfo 姓名:name 年龄:age 性别:gender 学校:school 注:学校和学生是一对多的关系,所以学生类中的学校正是体现这个关系 模型类需要继承自...数据库中表的命名为应用命_模型类名,而且在模型类中添加了外键则会生成命名为外键模型类名_id的外键字段。...: st1 = StudentInfo() st1.name = '张三' st1.age = 18 st1.gender = True # 直接赋值外键模型类对应的实例对象 st1.school =...在多类记录中访问一类直接使用st2.school即可,而在一类记录中访问多类可以使用 # 一类.多类名小写_set.all() 返回的是多类实例对象组成的列表 sc3.studentinfo_set.all

    1.9K10

    Django 1.10中文文档-第一个应用Part7-自定义管理站点

    在这个表单中,Question字段是一个select选择框,包含了当前数据库中所有的Question实例。Django在admin站点中,自动地将所有的外键关系展示为一个select框。...在我们的例子中,目前只有一个question对象存在。 请注意图中的绿色加号,它连接到Question模型。每一个包含外键关系的对象都会有这个绿色加号。...通俗讲就是,新建一个Question并作为当前Choice的外键。 但是,实话说,这种创建方式的效率不怎么样。...自定义项目模板 在项目的路劲下(包含manage.py的目录)创建一个名为templates目录。Templates可以放在你的文件系统中Django所能访问到的任何地方。...快速通道 Django 1.10中文文档-第一个应用Part1-请求与响应 Django 1.10中文文档-第一个应用Part2-模型和管理站点 Django 1.10中文文档-第一个应用

    3.6K60

    后端框架学习-Django

    ORM框架 ORM(对象关系映射),是一种程序技术,能够使用类和对象对数据库进行操作,从而避免通过SQL语句操作数据库。 作用 建立模型类和表之间的对应关系,允许我们通过面向对象的方式来操作数据库。...创建一对一数据 无外键的模型类,和之前相同 有外键的模型类: wife = Wife.objects.create(name=’王夫人’,author = author1(类属性名称绑实例...)) wife = Wife.objects.create(name=’王夫人’,author_id = 1(类属性字段绑值)) 一对一查询 正向查询:从外键查对象 反向查询:从对象查外键 调用反向属性查询到关联的一方...一对多查询 核心:正向属性(authors)和反向属性(book_set) 在多表上设置外键,关联一表。...无外键的模型类,和之前相同 有外键的模型类: 类似上面 wife = Wife.objects.create(name=’王夫人’,author = author1(类属性名称绑实例)

    9.6K40

    Django篇(一)

    当我们访问出现: ? 说明我们已经把项目运行起来了。 ORM框架 意思就是对象关系映射。 Django中内置ORM框架。运用这个框架让我们在操作数据库的时候更简单。...不用再写一些简单的Sql语句,通过创建一个类,来一一对应数据库中表的字段。 通过操作类来操作数据库中的表。所以在Models中就写和数据库中表,字段一样的类。...= models.ForeignKey('stuinfo') 多表联查有个外键,我们通过外键来查询 通过第一张表查询第二张表 s1 = student.objects.get(id = 1) # 这样就查询到...由上面我们得知:我们访问不同的页面在views中只是 模板不同,参数不同。 我们可以自己写一个方法来方便我们的操作。 ?...这样写了之后,我们依然可以访问,但是这样的代码不许需要我们来写,在Django中已经封装好了。 我们直接写成: ? 就可以达到和我们之前一样的效果。 4、如何使用views中的参数字典?

    1.1K30

    Django—入门

    可以,就是通过接下来要给大家讲的ORM框架。 ORM框架 O是object,也就类对象的意思,R是relation,翻译成中文是关系,也就是关系数据库中数据表的意思,M是mapping,是映射的意思。...django中内嵌了ORM框架,不需要直接面向数据库编程,而是定义模型类,通过模型类和对象完成数据表的增删改查操作。...Django框架根据我们设计的模型类生成了迁移文件,在迁移文件中我们可以看到fields列表中每一个元素跟BookInfo类属性名以及属性的类型是一致的。...在我们之后迁移生成表的时候,Django框架就会自动帮我们在图书表和英雄表之间建立一个外键关系。 最后我们可以看到数据库中生成的英雄表如下图: ?...hbook_id是根据HeroInfo类的关系属性hbook生成的,对应着图书表中的主键id。

    1.9K10

    面试前赶紧看了5道Python Web面试题,Python面试题No17

    “应用上下文” 的构造函数也和 “请求上下文” 类似,都有app、url_adapter等属性。“应用上下文” 存在的一个主要功能就是确定请求所在的应用。 第2题:django中间件的使用?...设计表时,尽量少使用外键,因为外键约束会影响插入和删除性能 使用缓存,减少对数据库的访问 orm框架下设置表时,能使用varchar确定字段长度时,就别用text 可以给搜索频率搞得字段属性,在定义时创建索引...() 在模板标签里使用with标签可以缓存Qset查询结果 第4题: 解释一下 Django 和 Tornado 的关系、差别?...Django 框架的核心组件有: 用于创建模型的对象关系映射为最终用户设计的完美管理界面一流的 URL 设计设计者友好的模板语言缓存系统等等 它鼓励快速开发,并遵循MVC设计。...Django遵守 BSD版权,最新发行版本是Django1.4,于2012年03月23日发布.Django的主要目的是简便、快速的开发数据库驱动的网站。

    2.9K30

    web开发框架之Django基础

    utf-8这个属性是可写的,可以通过修改它来                 修改访问表单数据使用的编码, 接下来对属性的任何访问将使用新的encoding值 FILES...)) # 由多到一的访问语法 -->多对应模型类对象,一对应模型类中的关系类属性名 hero = HeroInfo.objects.get(id=1) print(hero.hbook...) #访问一对应的模型类关联对象的id语法:多对应的模型类对象.关联类属性_id hero = HeroInfo.objects.get(id=1) print(hero.hbook_id...语法如下: # 一模型类关联属性名__一模型类属性名__条件运算符=值 # 注意:如果没有"__运算符"部分,表示等于 # 查询书名为天龙八部中的所欲英雄...我们在通过模型类的objects属性提供的方法操作数据库时, 即是在使用一个管理器对象objects。

    6.1K10

    python基础菜鸟教程_菜鸟课程好还是文都好

    采用了MTV的框架模式,即模型M,视图V和模版T。Django的主要目的是简便、快速的开发数据库驱动的网站。...它还强调快速开发和DRY(Do Not Repeat Yourself)原则。 2.新建Django项目。...3.urls简介 在Django中,要访问一个自己新建的项目,最简单的也是不可缺少的步骤有三:设置urls、编写视图函数、通过浏览器访问。...template_name:要使用的模板的完整名称,可选的参数 context:添加到模板上下文的一个字典。默认是一个空字典。如果字典中的某个值是可调用的,视图将在渲染模板之前调用它。...render方法主要是将从服务器提取的数据,填充到模板中,然后将渲染后的html静态文件返回给浏览器。这里一定要注意:render渲染的是模板。

    1.7K10

    关于“Python”的核心知识点整理大全53

    前面我们给模型Entry定义了属性topic,这是一个 ForeignKey,将条目与主题关联起来。...of the game, roughly...>, <Entry: In the opening phase of the game, it's important t...>] 为通过外键关系获取数据...例如, 假设你有模型Pizza和Topping,而Topping通过一个外键关联到Pizza;如果你有一个名为my_pizza 的对象,表示一张比萨,就可使用代码my_pizza.topping_set.all...我们不会太多地使用shell,但应继续使用它来熟悉对存储在项目中的数据进 行访问的Django语法。 注意 每次修改模型后,你都需要重启shell,这样才能看到修改的效果。...18.3.3 编写模板 模板定义了网页的结构。模板指定了网页是什么样的,而每当网页被请求时,Django将填入 相关的数据。模板让你能够访问视图提供的任何数据。

    11010

    使用 Django + Vue.js 开发个人博客网站(完整版附源码)—— Python-课程设计-期末项目

    加上 属性(属性不全,在概念模型中会补全): ? 然后设计它的 概念模型 : ? 对应的 物理模型 为: ?...在物理模型中,由于存在一对多的关系,所以文章表和评论表中加上了两个 外键约束 。...但是要在配置文件中说明自己已经更改了用户类: # 替换系统的用户模型为我们自定义的用户模型 AUTH_USER_MODEL = 'users.User' 自动生成的 users 表: ?...3、登陆状态保持 状态保持: 将通过认证的用户的唯一标识信息(比如:用户ID)写入到当前 session 会话中; Django 用户认证系统提供了 login() 方法封装了写入 session...的操作,帮助我们快速实现状态保持; login() 位置:django.contrib.auth.

    6K40

    用python搭建一个校园维基网站(二)—— 可编辑内容的首页的创建

    在wagtail的概念中,页面模型和模板文件是默认关联的,如HomePage默认对应的模板为templates/home/home_page.html(注意命名的转换关系),而欢迎页http://127.0.0.1...我们的WikiHome页面模型中需要图中红色高亮的一系列字段,其中title字段继承自Page类,不用额外添加,image字段为连接到wagtailimages.Image模型的外键。...WikiHomeTopLink类似,为了层次上更清晰,采用了多重继承,在models.py中只定义ParentalKey外键,而在另一个文件中定义了RelatedLink模型,包含的字段有链接文本和具体链接...,只是具体链接可能为外链、某个页面或某个文档,占用了三个字段,此外还利用@property装饰器为该模型添加了link属性,来返回它的具体链接,这样在模板中就可以使用.link调用。...对于模板来说,它对应的页面模型处于它的上下文环境,在模板中可以调用到该页面模型中的所有元素(使用Django的模板语言)。我们要按照页面排版将元素填充进去。

    3.6K80

    Django框架学习(三)

    过程: 客户端访问/use_template/,服务器调用对应的视图函数,进行模板的渲染,给模板文件传递变量,将模板文件中的变量进行替换,获取替换之后的html内容,将替换之后的html内容返回给客户端...b)Django中的模板变量不能直接进行算术运算 2、模板控制语句:条件判断和for循环 a)条件判断:Django模板中在进行条件判断时候,比较操作符两边必须有空格 b)for循环:Django模板中的...4.数据库 ORM框架: 作用:将模型类和数据表进行对应,通过面向对象的方式进行数据库的操作。 flask中SQLALchemy Django中自带ORM框架,可以直接进行使用。...AutoField的选项使用 unique 如果为True, 这个字段在表中必须有唯一值,默认值是False 外键 在设置外键时,需要通过on_delete选项指明主表删除数据时,对于外键引用表数据如何处理...,在django.db.models中包含了可选常量: CASCADE 级联,删除主表数据时连通一起删除外键表中数据 PROTECT 保护,通过抛出ProtectedError异常,来阻止删除主表中被外键应用的数据

    1.8K40

    Django 3.1 官网学习路线

    字段还可以有各种可选参数;在本例中,我们将投票的默认值设置为 0。 最后,请注意使用外键定义了关系。这告诉 Django 每个选择都与一个问题相关。...Django 支持所有常见的数据库关系:多对一、多对多和一对一。 激活模型 这一小段模型代码为 Django 提供了大量信息。...按照惯例,Django 会将"_id"附加到外键字段名。(是的,你也可以重写这个。) 外键关系是通过外键约束来显式的。...In [6]: q.id Out[6]: 1 #通过Python属性访问模型字段值。 In [7]: q.question_text Out[7]: "What's new?"...“添加选择”表单如下所示: 在该表单中,“Question”字段是一个选择框,包含数据库中的每个问题。Django 知道一个外键应该在管理中表示为一个框。在我们的例子中,目前只存在一个问题。

    8.2K10
    领券