一: 一对多

  1. 一对多新增

两种方式:  publish = 对象    publish_id = id

  1. publish_id 和 publish 的区别就是:
    1)publish_id 可以手动输入要查询的书籍的出版社 如: 方式一
    2)publish 要查询书籍出版社需要从数据库中取出出版社对象, 如: 方式二

# 一对多新增数据
# 添加一本北京出版社出版的书
# 方式一
ret = Book.objects.create(name='妈妈再爱我一次', price=25, publish_id=1)
print(ret.name) # 方式二, 存对象publish=出版社的对象,存到数据库,是一个id
# publish=Publish.objects.get(id=2)
# publish=Publish.objects.get(pk=2)
# pk 和 id 的作用一样,都是主键,可以通过主键查找,主键只有一个
# 如果用filter 必须在后面加一个 .first()
publish = Publish.objects.filter(pk=2).first() # 从数据里面取出出版社对象
ret = Book.objects.create(name='爸爸再爱我一次', price=35, publish=publish)
print(ret.name)

 2. 一对多修改: 学习了单表操作,新增数据这一些,和修改数据是一个意思

# 一对多修改数据
# 方式一:
book = Book.objects.get(pk=1)
# book.publish=出版社对象
book.publish_id = 2
book.save() # 方式二
# book=Book.objects.filter(pk=1).update(publish=出版社对象)
# book=Book.objects.filter(pk=1).update(publish_id=1)

  3. 一对多删除: 删除数据就是直接删除就可以了,不过删除大数据要谨慎,能虚就虚,不然就要删库跑路了

二: 多对多

  - 多对多常用的API

    # book_obj.authors.add() 添加
# book_obj.authors.remove() 特定的关联对象从集合中去除, 比如说,移除某书籍的作者
# book_obj.authors.clear() 清空所有书籍的作者
# book_obj.authors.set() 先清空,再设置

 1. 多对多新增,add

 # 多对多新增(书籍跟作者的关系)
# 1. 为妈妈再爱我一次这本书新增一个叫prince, bp 的作者
# prince = Author.objects.filter(name='prince').first() # 拿到作者这个对象
# bp = Author.objects.filter(name='bp').first() # 新增两个作者
book = Book.objects.filter(name='妈妈再爱我一次').first() # 要新增就要查到这本书
# add 添加多个对象 对象用逗号隔开
# book.author.add(prince, bp) # 书籍表的authors
# add 添加作者id
book.author.add(1, 2)

 2. 多对多删除,remove

    # 多对多新增(书籍跟作者的关系)
# prince = Author.objects.filter(name='prince').first() # 拿到作者这个对象
# book = Book.objects.filter(name='妈妈再爱我一次').first() # 要新增就要查到这本书
# # 删除 remove ,可以传对象, 可以传id, 也可以传多个,但不要混着用
# 删除一个叫prince的作者
# book.author.remove(prince)
# book.author.remove(2)
book.author.remove(1, 2)

3. 清空, clear

 # 清空 clear,清空所有,不需要传参数
book.author.clear()

4. 先清空, 在新增 set

 # 先清空,在新增 set ,
book.author.set(2) # 注意: 这样是错误的, 打印时会出现 TypeError: 'int' object is not iterable 这样的错误, 我们必须传一个可迭代的对象出来, 改成下面这样,就可以了
# 要传一个列表,列表内可以是id, 也可以是对象
book.author.set([2, ])

2.

2.

2.

Django day08 多表操作 (二) 添加表记录的更多相关文章

  1. {django模型层(二)多表操作}一 创建模型 二 添加表记录 三 基于对象的跨表查询 四 基于双下划线的跨表查询 五 聚合查询、分组查询、F查询和Q查询

    Django基础五之django模型层(二)多表操作 本节目录 一 创建模型 二 添加表记录 三 基于对象的跨表查询 四 基于双下划线的跨表查询 五 聚合查询.分组查询.F查询和Q查询 六 xxx 七 ...

  2. 百万年薪python之路 -- MySQL数据库之 MySQL行(记录)的操作(二) -- 多表查询

    MySQL行(记录)的操作(二) -- 多表查询 数据的准备 #建表 create table department( id int, name varchar(20) ); create table ...

  3. Excel:一维表和二维表 互转

    一.一维表转二维表 数据源: 一份流水账式的值班表,为了便于打印张贴,现在需要使其变成这样的样式: 也就是从一维表变成传说中的二维表. 1.新建查询 依次单击[数据]→[新建查询] →[从文件]→[从 ...

  4. linux 进阶2--C++读取lua文件中的变量、一维表、二维表

    lua 语言非常灵活,一般把lua 作为脚本文件,会用C++与之进行交互.最重要的是C++代码能读取到脚本中的变量.一维表.二维表. 这样有些参数就可以在lua文件进行更改,而不用重新更改C++代码. ...

  5. Django day08 多表操作 (一) 多表模型创建

    多表模型创建分析:1)作者表:一个作者有姓名和年龄2)作者信息表: 有作者就有信息,点击作者的名字可以查询他的电话和地址, 作者表对应作者信息表,所以他们之间是一对一对的关系3)出版社表: 出版社有对 ...

  6. Django学习笔记(7)——单表操作和多表操作

    单表操作 1,创建模型 创建名为book的APP,在book下的models.py中创建模型: from django.db import models # Create your models he ...

  7. 09 ORM 多表操作,创建表,添加记录

    1.数据库表关系 1.一对多 为什么需要,重复字段太多 一对多关系表 Book id title price publish_id 1 python 100 1 2 php 200 2 3 go 10 ...

  8. Django模型层:单表操作,多表操作,常用(非常用)字段和参数,Django-model进阶

    一.web应用 二.模板的导入与继承 三.静态文件相关 四.inclusion_tag:返回html片段 五.模型层 一.web应用 -s包括两个部分:web服务器+application -目前阶段 ...

  9. Django之model联表:一对多、跨表操作,联表查询

    表结构概述 model.py : class Something(models.Model): name = models.CharField(max_length=32) class UserTyp ...

随机推荐

  1. django-Celery分布式队列简单使用

    介绍: Celery 是一个简单.灵活且可靠的,处理大量消息的分布式系统,并且提供维护这样一个系统的必需工具. 它是一个专注于实时处理的任务队列,同时也支持任务调度. worker:是一个独立的进程, ...

  2. 为.net mvc core 启用 https

    引用nuget包:Microsoft.AspNetCore.Server.Kestrel.Https这是一个服务器测试ssl密钥,密码如代码里面所示 using System; using Syste ...

  3. 微信小程序animation

    wxml <view class="background" animation="{{rotateData}}"> </view>< ...

  4. STL源码分析之迭代器

    前言 迭代器是将算法和容器两个独立的泛型进行调和的一个接口. 使我们不需要关系中间的转化是怎么样的就都能直接使用迭代器进行数据访问. 而迭代器最重要的就是对operator *和operator-&g ...

  5. Linux之网络文件共享服务(SamBa)

    SMB:Server Message Block服务器消息块,IBM发布,最早是DOS网络文 件共享协议 Cifs:common internet file system,微软基于SMB发布 SAMB ...

  6. 内存_RAM或ROM_和FLASH存储的真正区别总结

    http://blog.sina.com.cn/s/blog_4b37304d0100fg10.html

  7. hdu 5170 精度控制

    众所周知,GTY是一位神犇,为了更好的虐场,他从来不写数学作业而是去屠题,他的数学老师非常不爽,但由于GTY每次考试都AK,她也不能说什么,有一天老师在黑板上写了四个数——a,b,c,da,b,c,d ...

  8. Huawei-R&S-网络工程师实验笔记20190527-华为设备密码重置、设置web管理

    >Huawei-R&S-网络工程师实验笔记20190527-华为设备密码重置.设置web管理 >>实验开始(使用SecureCRT 等工具软件): 一.华为设备密码重置,通过 ...

  9. jquery源码分析(五)——Deferred 延迟对象

    javascript的异步编程 为什么要使用异步编程? JS是单线程语言,就简单性而言,把每一件事情(包括GUI事件和渲染)都放在一个线程里来处理是一个很好的程序模型,因为这样就无需再考虑线程同步这些 ...

  10. 4、ceph-deploy之配置使用对象存储

    从firefly(v0.80)版本开始,ceph存储显著的简化了安装和配置Ceph Object Gateway, Gateway进程嵌入到Civetweb,所以你需要安装一个web服务,或者配置Fa ...