django 多对多表的创建和插入代码实现


Posted in Python onSeptember 09, 2019

这篇文章主要介绍了django-多对多表的创建和插入代码实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

表的创建

# 作者和书籍之间的多对多关系  
class Author(models.Model):
  '''
  作者表
  '''
  nid = models.AutoField(primary_key=True)
  name = models.CharField(verbose_name='作者名称',max_length=32)
  # 第一种方式直接在作者表中创建ManyToManyField字段(ORM会自动帮我们创建第三张表推荐这种方式)
  author2books = models.ManyToManyField(to='Books')
class Books(models.Model):
  '''
  书籍名称
  '''
  nid = models.AutoField(primary_key=True)
  title = models.CharField(verbose_name='书本名称',max_length=32)
  pid = models.ForeignKey(verbose_name='出版社ID',to='Press',to_field='nid',on_delete=models.CASCADE)
# 第二钟方式手动创建第三张表
# class Books2Author(models.Model):
#   '''
#   书本作者对应表
#   '''
#   nid = models.AutoField(primary_key=True)
#   aid = models.ForeignKey(verbose_name='作者ID',to='Author',to_field='nid')
#   bid = models.ForeignKey(verbose_name='书籍ID',to='Books',to_field='nid')

数据的添加

# 编辑作者
def edit_author(request):
  # 获取作者ID 
  id = request.GET.get('id')
  # 获取所有书籍
  books_lst = models.Books.objects.all()
  # 根据作者ID 获取到作者对象
  author_info = models.Author.objects.filter(pk=id).first()
  if request.method == 'POST':
    # 获取前端传过来的作者新名称
    name = request.POST.get('name')
    # 获取前端传递过来的书籍
    book_lst = request.POST.getlist('books')
    # 根据新名称,更新当前名称
    author_info.name = name
    # 保存数据
    author_info.save()
    # set方法会将当前作者原先的书籍全部删除,然后插入前端传递过来的书籍列表(参数为list类型)
    author_info.author2books.set(book_lst)
    # add方法会将前端传递过来书籍添加到 作者和书籍的对应表中。如果插入重复记录会报错(参数为单个元素,可以插入多个)
    # author_info.author2books.add(*book_lst)
    return redirect('/author_lst/')
  return render(request,'edit_author.html',{'books_lst':books_lst,'author_info':author_info})

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
在python的WEB框架Flask中使用多个配置文件的解决方法
Apr 18 Python
python编写网页爬虫脚本并实现APScheduler调度
Jul 28 Python
pygame学习笔记(5):游戏精灵
Apr 15 Python
python方向键控制上下左右代码
Jan 20 Python
python实现寻找最长回文子序列的方法
Jun 02 Python
Python在图片中插入大量文字并且自动换行
Jan 02 Python
对Python3 goto 语句的使用方法详解
Feb 16 Python
pytorch获取vgg16-feature层输出的例子
Aug 20 Python
python pygame实现滚动横版射击游戏城市之战
Nov 25 Python
Python如何基于rsa模块实现非对称加密与解密
Jan 03 Python
使用openCV去除文字中乱入的线条实例
Jun 02 Python
python asyncio 协程库的使用
Jan 21 Python
Python中的单下划线和双下划线使用场景详解
Sep 09 #Python
python 批量修改 labelImg 生成的xml文件的方法
Sep 09 #Python
Python定时发送天气预报邮件代码实例
Sep 09 #Python
python英语单词测试小程序代码实例
Sep 09 #Python
Python实现TCP通信的示例代码
Sep 09 #Python
Python3使用PySynth制作音乐的方法
Sep 09 #Python
python智联招聘爬虫并导入到excel代码实例
Sep 09 #Python
You might like
简单介绍PHP的责任链编程模式
2015/08/11 PHP
解读IE和firefox下JScript和HREF的执行顺序
2008/01/12 Javascript
jQuery总体架构的理解分析
2011/03/07 Javascript
用Javascript实现Windows任务管理器的代码
2012/03/27 Javascript
javascript 事件处理、鼠标拖动效果实现方法详解
2012/05/11 Javascript
JS 新增Cookie 取cookie值 删除cookie 举例详解
2014/10/10 Javascript
javascript实现淡蓝色的鼠标拖动选择框实例
2015/05/09 Javascript
JS采用绝对定位实现回到顶部效果完整实例
2016/06/20 Javascript
JS获取html元素的标记名实现方法
2016/10/08 Javascript
webpack实现热加载自动刷新的方法
2017/07/30 Javascript
node.js使用免费的阿里云ip查询获取ip所在地【推荐】
2018/09/03 Javascript
node.js学习笔记之koa框架和简单爬虫练习
2018/12/13 Javascript
JavaScript错误处理操作实例详解
2019/01/04 Javascript
ES6 Iterator接口和for...of循环用法分析
2019/07/31 Javascript
Vue3项目打包后部署到服务器 请求不到后台接口解决方法
2020/02/06 Javascript
浅谈js数组splice删除某个元素爬坑
2020/10/14 Javascript
Python 正则表达式操作指南
2009/05/04 Python
Python多重继承的方法解析执行顺序实例分析
2018/05/26 Python
python接口自动化(十六)--参数关联接口后传(详解)
2019/04/16 Python
Python中的引用知识点总结
2019/05/20 Python
python 求某条线上特定x值或y值的点坐标方法
2019/07/09 Python
python单例模式原理与创建方法实例分析
2019/10/26 Python
如何基于python生成list的所有的子集
2019/11/11 Python
tensorflow 动态获取 BatchSzie 的大小实例
2020/06/30 Python
python判断是空的实例分享
2020/07/06 Python
基于python爬取链家二手房信息代码示例
2020/10/21 Python
python日志通过不同的等级打印不同的颜色(示例代码)
2021/01/13 Python
pandas按条件筛选数据的实现
2021/02/20 Python
在家更换处方镜片:Lensabl
2019/05/01 全球购物
Chi Chi London官网:购买连衣裙和礼服
2020/10/25 全球购物
市场营销专科应届生求职信
2013/11/24 职场文书
高三毕业生自我鉴定
2013/12/20 职场文书
《赵州桥》教学反思
2014/02/17 职场文书
升学宴祝酒词
2015/08/11 职场文书
2016年师德先进个人事迹材料
2016/02/29 职场文书
用Python爬取各大高校并可视化帮弟弟选大学,弟弟直呼牛X
2021/06/11 Python