关系表的操作语句:

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

增:

# 一对一

# (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. Docker安装yapi

    安装docker 1.安装依赖包: yum install -y yum-utils device-mapper-persistent-data lvm2 2.安装 Yum -y install do ...

  2. npm小工具、技巧合集:让你的npm“健步如飞”

    1.解决安装速度慢问题-nrm 解决痛点 由于npm的包仓库是在国外,npm包安装速度较慢,部分包甚至无法安装. 对比cnpm的优势 1.cnpm增加了大脑的记忆和思维负担,常常需要考虑使用npm还是 ...

  3. C#读写ini

    using System; using System.IO; using System.Runtime.InteropServices; using System.Text;   namespace ...

  4. AWVS 安全渗透扫描

    1.打开软件,点击 New Scan 2.在 website url 中输入被扫描的网址,点击 next 3.在 scanning profile 中选择测试的漏洞类型,默认选择 default(默认 ...

  5. python ——文件的操作大全,如with..as

    工作中遇到了需要对json文件进行增删内容操作的需要,于是系统性的整理了一下关于文件的基本操作这里的知识点: 结构:新建文件→打开文件→读取文件→关闭文件 一.基本文件操作 1.新建文件(打开文件), ...

  6. MySQL 8.0.20 源码安装数据库软件

    官方支持的平台: https://www.mysql.com/support/supportedplatforms/database.html

  7. Fibonacci相关问题

    公式如下: 递归的解法我就不写了,贴一个递推的. long long Fibonacci(unsigned int n) { ) ; ) ; ; ; long long res; ; i <= ...

  8. P3983 赛斯石(双背包)

    这题不算难的,但是脑子真的特别乱.....传送门 \(Ⅰ.物品可以拆开来但船不能拆开来,所以1-10载重船的最大收益完全可以用背包求出来.\) \(Ⅱ.最后一定是选一些船走,而船的收益已经固定.所以用 ...

  9. B. Silly Mistake Codeforces Round #600 (Div. 2)

    B. Silly Mistake 题目大意: 首先定义有效的一天: 每一个不同的数字只能进去一次,出来一次,正数代表进去,负数代表出来 每一个人不能过夜 不合理: 一个数字只有进去,或者只有出来则是无 ...

  10. Java中的内存

    目录 栈(Stack):存放的都是方法中的局部变量.方法的运行一定要在栈当中. 堆(Heap):凡是new出来的东西,都在堆内存当中 方法区(Method Area):存储.class相关信息,包含方 ...