关系表的操作语句:

以上一节中创建的书籍、出版社、作者、作者信息表为例进行:

增:

# 一对一

# (1)类属性外键关联,使用外键约束属性直接进行对象关联插入

author_detail_obj=models.AuthorDetail.objects.get(id=4)

author_obj = models.Author.objects.create(author_name='脉动',author_birth='2010-10-10',author_detail=author_detail_obj)

# 2)外键关联的字段进行指定值插入

# author_obj = models.Author.objects.create(author_name='脉动', author_birth='2010-10-10',author_detail_id=4)

# 多对一

# 1)类属性外键关联,使用外键约束属性直接进行对象关联插入

publish_obj=models.Publish.objects.get(id=3)

book_obj=models.Book.objects.create(book_name='时光不散',book_price=22,book_publisher=publish_obj)

# 2)外键关联的字段进行指定值插入

# book_obj = models.Book.objects.create(book_name='时光不散', book_price=22, book_publisher=3)

# 多对多(基于对象)

author_obj1=models.Author.objects.get(id=1)

author_obj2=models.Author.objects.get(id=3)

book_obj=models.Book.objects.get(book_name='小时光')

# (1)调用对象属性的方法传入关联对象进行插入

book_obj.author.add(author_obj1,author_obj2)

# 2)调用对象属性的方法直接传入id进行插入

# book_obj.author.add(1,3)

# book_obj.author.add(*[1,3])

删(多表关联是默认都是级联删除,和单表的删除操作一样直接删):

# 一对一

models.Author.objects.filter(author_name='无名').first().delete()

# 多对一

models.Book.objects.filter(book_name='完美世界').delete()

# 多对多(基于对象)

author_obj1=models.Author.objects.get(pk=1)

author_obj2= models.Author.objects.get(author_name='差不多先生')

book_obj=models.Book.objects.filter(book_name='小时光')[0]

   #remove指定删除

# 1)使用remove传递对象参数

book_obj.author.remove(author_obj1,author_obj2)

# 2)使用remove传递字段参数

# book_obj.author.remove(author_obj1.id, author_obj2.id)

# book_obj.author.remove(1,2)

# book_obj.author.remove(*[1,2])

  # clear直接清除所有

book_obj.author.clear()

改:

# 一对一

models.Author.objects.filter(author_name='差不多先生').update(author_name='金庸')

# 多对一

models.Book.objects.filter(book_price=22).update(book_price=11)

# 多对多(基于对象)

book_obj=models.Book.objects.get(id=5)

# 先清除再设置(set只能给一个参数,数字或者字符型数字均可)

book_obj.author.set([1,2,'7'])

在多表增删改操作中,一对一和多对一关系表与单表的操作一样;多对多(自动创建的第三张表)都是基于对象操作,使用多对多约束的属性(第三张表)调用orm提供的add、remove、clear、set方法进行增删改查操作,参数可以为指定的字段值,也可以使用指定的对象作为参数

Django之ORM多表增删改操作的更多相关文章

  1. ORM多表增删改查

    一 创建多表 在models.py里创建4张表:Author(作者).AuthorDetail(作者详细信息).Publish(出版社).Book(书) 四张表关系为: (1)首先创建一对一关系.On ...

  2. day 69 ORM 多表增删改查操作

    http://www.cnblogs.com/liwenzhou/p/8660826.html 下面的代码是在 python console中配置的. 关闭pycharm会消失. from app01 ...

  3. Django - 基于orm实现用户增删改查

    1.基于orm实现用户新增 user_info.html中,增加代码: views.py中,在原user_info函数中,增加判断代码: 备注:最后一句,可以通过return redirect 实现, ...

  4. Django框架(九)—— 单表增删改查,在Python脚本中调用Django环境

    目录 单表增删改查,在Python脚本中调用Django环境 一.数据库连接配置 二.orm创建表和字段 三.单表增删改查 1.增加数据 2.删除数据 3.修改数据 4.查询数据 四.在Python脚 ...

  5. Django项目的创建与介绍.应用的创建与介绍.启动项目.pycharm创建启动项目.生命周期.三件套.静态文件.请求及数据.配置Mysql完成数据迁移.单表ORM记录的增删改查

    一.Django项目的创建与介绍 ''' 安装Django #在cmd中输入pip3 #出现这个错误Fatal error in launcher: Unable to create process ...

  6. ORM之单表增删改查

    ORM之单表增删改查 在函数前,先导入要操作的数据库表模块,model from model所在的路径文件夹 import model   在views文件中,加的路径: #就一个app01功能的文件 ...

  7. [Django框架 - 静态文件配置、request对象方法初识、 pycharm链接数据库、ORM实操增删改查、django请求生命周期]

    [Django框架 - 静态文件配置.request对象方法初识. pycharm链接数据库.ORM实操增删改查.django请求生命周期] 我们将html文件默认都放在templates文件夹下 将 ...

  8. Django框架(八)--单表增删改查,在Python脚本中调用Django环境

    一.数据库连接配置 如果连接的是pycharm默认的Sqlite,不用改动,使用默认配置即可 如果连接mysql,需要在配置文件中的setting中进行配置: 将DATABASES={} 更新为 DA ...

  9. OracleHelper(对增删改查分页查询操作进行了面向对象的封装,对批量增删改操作的事务封装)

    公司的一个新项目使用ASP.NET MVC开发,经理让我写个OracleHelper,我从网上找了一个比较全的OracleHelper类,缺点是查询的时候返回DataSet,数据增删改要写很多代码(当 ...

随机推荐

  1. CF1285 --- Dr. Evil Underscores

    CF1285 --- Dr. Evil Underscores 题干 Today as a friendship gift, Bakry gave Badawy \(n\) integers \(a_ ...

  2. 15个 MySQL 基础面试题,DBA 们准备好了吗?

    此前我们已经有发表过Linux 面试基础问答之一.二和三共3篇文章,获得读者的好评,同时我们得到反馈,有些读者希望这种交互式学习方法能够做得更加灵活.心动不如行动,我们这就为您奉上 15个 MySQL ...

  3. 解决 Retrofit 多 BaseUrl 及运行时动态改变 BaseUrl ?

    原文地址: juejin.im/post/597856- 解决Retrofit多BaseUrl及运行时动态改变BaseUrl(一) 解决Retrofit多BaseUrl及运行时动态改变BaseUrl( ...

  4. 运用shell脚本 执行sftp,ftp命令

    sftp文件上传(从本地上传到远程) #!/bin/bash #远程上传文件测试 if [ $# -ne 2 ] then echo "miss arguments" echo & ...

  5. resetlogs 打开数据库时新生成日志位置问题

    若系统中缺少联机日志,以resetlogs方式重建控制文件,那么当我们以alter database open resetlogs方式打开数据库时,新生成的联机日志会位于何处? 一:下面分别讨论几种情 ...

  6. 两个命令把 Vim 打造成 Python IDE

    运行下面两个命令,即可把 Vim(含插件)配置成 Python IDE.目前支持 MAC 和 Ubuntu. Shell   curl -O https://raw.githubusercontent ...

  7. SpringBoot上传文件大小限制

    SpringBoot默认上传文件大小不能超过1MB,超过之后会报以下异常: org.apache.tomcat.util.http.fileupload.FileUploadBase$FileSize ...

  8. Coursera课程笔记----计算导论与C语言基础----Week 4

    感性认识计算机程序(Week 4) 引入 编程序 = 给计算机设计好运行步骤 程序 = 人们用来告诉计算机应该做什么的东西 问题➡️该告诉计算机什么?用什么形式告诉? 如果要创造一门"程序设 ...

  9. Qt之xml文件解析

    XML文件简介 XML - EXtensible Markup Language,可拓展标记语言 Qt中加载XML模块 .pro 文件中添加 QT += xml Qt的XML访问方式 引用:https ...

  10. 美团分布式ID生成框架Leaf源码分析及优化改进

    本文主要是对美团的分布式ID框架Leaf的原理进行介绍,针对Leaf原项目中的一些issue,对Leaf项目进行功能增强,问题修复及优化改进,改进后的项目地址在这里: Leaf项目改进计划 https ...