关系表的操作语句:

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

增:

# 一对一

# (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. 2019-2020-1 20199326《Linux内核原理与分析》第九周作业

    进程的切换和系统的一般执行过程 中断 中断在本质上都是软件或者硬件发生了某种情形而通知处理器的行为,处理器进而停止正在运行的指令流(当前进程),对这些通知做出相应反应,即转去执行预定义的中断处理程序( ...

  2. LeetCode7-ReverseInteger

    LeetCode7-ReverseInteger LeetCodeeasyOverflow 题目 题目所在链接为 LeetCode-7:ReverseInteger 题目描述 给出一个32位的有符号整 ...

  3. java中ThreadLocal的使用

    文章目录 在Map中存储用户数据 在ThreadLocal中存储用户数据 java中ThreadLocal的使用 ThreadLocal主要用来为当前线程存储数据,这个数据只有当前线程可以访问. 在定 ...

  4. Spring Boot filter

    在Spring Boot中自定义filter 本文我们将会讲解如何在Spring Boot中自定义filter并指定执行顺序. 定义Filter很简单,我们只需要实现Filter接口即可,同时我们可指 ...

  5. Robot Framework -002 在Windows10上的安装

    机器人框架是使用Python实现的,并且还支持Jython(JVM),IronPython(.NET)和PyPy. 在安装框架之前,一个明显的前提条件是至少安装这些解释器之一. 下面列出了安装Robo ...

  6. mac OS 配置 svn服务器端

    在Windows环境下 一般使用Tortoise SVN来搭建svn环境 操作系统 mac OS High Sierra 10.13.6 在Mac环境下 由于Mac自带了svn的服务器端和客户端功能 ...

  7. CF思维联系– CodeForces -CodeForces - 992C Nastya and a Wardrobe(欧拉降幂+快速幂)

    Nastya received a gift on New Year - a magic wardrobe. It is magic because in the end of each month ...

  8. Jmeter 后置处理器

    1.JSON Extractor Json extractor 后置处理器用在返回格式为 Json 的 HTTP 请求中,用来获取返回的 Json 中的某个值.并保存成变量供后面的请求进行调用或断言等 ...

  9. file download hash mismatch

    在linux中使用cmake时,遇到了"file download hash mismatch",同时status显示"unsupported protocol" ...

  10. c/c++获取硬盘序列号

    最近在接触软件注册模块,需要获取硬盘序列号来生成注册码. 硬盘序列号,英文名:Hard Disk Serial Number,该号是硬盘厂家为区别产品而设置的,是唯一的.网上搜索一下,发现获取硬盘序列 ...