Django之ORM多表增删改操作
关系表的操作语句:
以上一节中创建的书籍、出版社、作者、作者信息表为例进行:
增:
# 一对一
# (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多表增删改操作的更多相关文章
- ORM多表增删改查
一 创建多表 在models.py里创建4张表:Author(作者).AuthorDetail(作者详细信息).Publish(出版社).Book(书) 四张表关系为: (1)首先创建一对一关系.On ...
- day 69 ORM 多表增删改查操作
http://www.cnblogs.com/liwenzhou/p/8660826.html 下面的代码是在 python console中配置的. 关闭pycharm会消失. from app01 ...
- Django - 基于orm实现用户增删改查
1.基于orm实现用户新增 user_info.html中,增加代码: views.py中,在原user_info函数中,增加判断代码: 备注:最后一句,可以通过return redirect 实现, ...
- Django框架(九)—— 单表增删改查,在Python脚本中调用Django环境
目录 单表增删改查,在Python脚本中调用Django环境 一.数据库连接配置 二.orm创建表和字段 三.单表增删改查 1.增加数据 2.删除数据 3.修改数据 4.查询数据 四.在Python脚 ...
- Django项目的创建与介绍.应用的创建与介绍.启动项目.pycharm创建启动项目.生命周期.三件套.静态文件.请求及数据.配置Mysql完成数据迁移.单表ORM记录的增删改查
一.Django项目的创建与介绍 ''' 安装Django #在cmd中输入pip3 #出现这个错误Fatal error in launcher: Unable to create process ...
- ORM之单表增删改查
ORM之单表增删改查 在函数前,先导入要操作的数据库表模块,model from model所在的路径文件夹 import model 在views文件中,加的路径: #就一个app01功能的文件 ...
- [Django框架 - 静态文件配置、request对象方法初识、 pycharm链接数据库、ORM实操增删改查、django请求生命周期]
[Django框架 - 静态文件配置.request对象方法初识. pycharm链接数据库.ORM实操增删改查.django请求生命周期] 我们将html文件默认都放在templates文件夹下 将 ...
- Django框架(八)--单表增删改查,在Python脚本中调用Django环境
一.数据库连接配置 如果连接的是pycharm默认的Sqlite,不用改动,使用默认配置即可 如果连接mysql,需要在配置文件中的setting中进行配置: 将DATABASES={} 更新为 DA ...
- OracleHelper(对增删改查分页查询操作进行了面向对象的封装,对批量增删改操作的事务封装)
公司的一个新项目使用ASP.NET MVC开发,经理让我写个OracleHelper,我从网上找了一个比较全的OracleHelper类,缺点是查询的时候返回DataSet,数据增删改要写很多代码(当 ...
随机推荐
- 解决Oracle在命令行下无法使用del等键问题
前言: Oracle使用Linux命令行进行编辑? 有PL/SQL development,SQL development等工具,为何用Linux命令行? 但也免不了有用的的时候 以下是解决在Linu ...
- Pytorch使用PIL的读取单张图片并显示
1. Image.open(fp, mode="r") 调用此方法需要引入头文件:from PIL import Image. 参数说明: fp:图片路径,可为绝对路径或相对路径. ...
- 从零开始创建CocoaPods私有库
为什么要创建CocoaPods私有库? 避免重复的造轮子 节约时间,方便管理自己的代码 精益求精 创建CocoaPods私有库 1.创建私有仓库工程 执行命令pod lib create SmartB ...
- python(open 文件)
一.open 文件 1.open('file','mode')打开一个文件 file 要打开的文件名,需加路径(除非是在当前目录) mode 文件打开的模式 需要手动关闭 close 2.with o ...
- ASP.NET Core 包管理工具(4)
之前忘记介绍ASP.NET Core静态文件wwwroot了.再来补充一下.步骤比较简单在项目上右击添加文件夹输入文件名称 wwwroot就搞定了.这个文件主要是放置一些静态文件的,比如css.js. ...
- E. Count The Blocks(找数学规律)
\(\color{Red}{先说一下自己的歪解(找规律)}\) \(n=1是答案是10\) \(n=2时答案是180\) \(n=3时模拟一下,很容易发现答案是2610\ \ 180\ \ 10\) ...
- shell命令之巧用cut
需求:取出日志中ip字段,并进行统计排序 .一般用用awk命令 假如ip地址为第一个字段 那么 awk ‘{print $1}’ 文件名 |sort |uniq -c|sort-nr 那如果不是第一个 ...
- 3、Hive-sql优化,数据倾斜处理
一.Hive-sql优化 #增加reducer任务数量(拉取数量分流) ; #在同一个sql中的不同的job是否可以同时运行,默认为false set hive.exec.parallel=true; ...
- 【Hadoop离线基础总结】伪分布模式环境搭建
伪分布模式环境搭建 服务规划 适用于学习测试开发集群模式 步骤 第一步:停止单节点集群,删除/export/servers/hadoop-2.7.5/hadoopDatas,重新创建文件夹 停止单节点 ...
- [工具]微软的学习平台Microsoft Learn很好用,推荐一下
1. 什么是Microsoft Learn Microsoft Learn是微软这两年大力推广的全新学习平台,可提供 Microsoft 产品交互式学习体验.基本上无需登录即可使用,但登录后可以使用更 ...