表关系:
1 一对多
2 多对多
3 一对一 添加记录: 一对多:书与出版社 #创建一对多:
publish=models.ForeignKey("Publish")
注意:publish不用写成publish_id,"Publish" 默认找Publish表的主键
#添加记录方式1:
models.Book.objects.create(name='红楼梦',publish_id=1)
#添加记录方式2:
# pubObj=models.Publish.objects.filter(name="人民出版社")[0]
# models.Book.objects.create(name='红楼梦',publish=pubObj) # 关联的出版社对象 多对多:书与作者
创建多对多关系:
authorlist=models.ManyToManyField("Author")
多对多添加记录:
先创建Book对象,→ 对象.authorlist.add(作者对象) book_obj=models.Book.objects.create(title="追风筝的人", price=100, publishDate="2017-12-12", publish_id=2) alex_obj=models.Author.objects.filter(name="alex")[0]
egon_obj=models.Author.objects.filter(name="egon")[0] book_obj.authorlist.add(alex_obj,egon_obj)
      
解除多对多关系:
先找到书对象→书对象.authorlist.remove(作者对象) 清除多对多关系:
先找到书对象→书对象.authorlist.clear()
一对一:
创建一对一关系
创建出版社与出版社详情一对一关系:
pubdetail=models.OneToOneField('Pubdetail')   在创建表的关联时 也可以指定哪个表和哪个字段,用 to 的形式
    models.ForeignKey(to="Publish",to_field="nid") 多对多和多对一同理 查询记录:
正向查询:
一对多:
linux_obj=models.Book.objects.filter(title="linux").first()
print(linux_obj.publish.name) # 与这本书对象关联的出版社对象的名字 多对多:
先找到要找的书对象→对象.authorlist.all()
linux_obj=models.Book.objects.filter(title="linux").first()
print(linux_obj.authorlist.all()) # 与这本书关联的所有作者对象集合 一对一:
查找书的出版社的地址
先找到书对象→出版社对象→出版社对象.pubdetail.addr
反向查询: book_set 是在创建关系的时候默认创建的,用于反向查询 #一对多的反向查询: eg:人民出版社出版过的书籍的名字
先找到出版社对象→出版社对象.book_set.all()
publish_obj=models.Publish.objects.filter(name="人民出版社")[0]
print(publish_obj.book_set.all()) # 与该年出版社关联的所有书籍对象的集合 #多对多的反向查询: 查询yuan出版过的所有书籍的名字和价格:
先找到作者对象→作者对象.book_set.all()
author_yuan=models.Author.objects.get(name="yuan")
print(author_yuan.book_set.all()) # 与该作者关联的所有书籍书籍对象的集合 #一对一的反向查询:
查找地址为北京的出版社出版的所有书
出版社详情表的对象.pubdetail.book.all() 注意:在已有记录的表中新增字段时需设置默认值(让已有的记录在该字段显示默认值),并且重新迁移数据库

直接赋值:
通过赋值一个新的可迭代的对象,关联对象集可以被整体替换掉。 >>> new_list = [obj1, obj2, obj3]
>>> book_obj.author = new_list
#直接替换 ,多对一和一对一想换值同样可以使用直接替换 book_obj.publish=new_publish_obj .....
如果外键关系满足null=True,关联管理器会在添加new_list中的内容之前,首先调用clear()方法来解除关联集中一切已存在对象的关联。否则, new_list中的对象会在已存在的关联的基础上被添加。

 


python-day71--django多表操作的更多相关文章

  1. Python之Django--ORM连表操作

    一对多 class UserType(models.Model): caption = models.CharField(max_length=32) class UserInfo(models.Mo ...

  2. Python - SQLAlchemy之连表操作

    ORM的两种创建方式 数据库优先:指的是先创建数据库,包括表和字段的建立,然后根据数据库生成ORM的代码,它是先创建数据库,再创建相关程序代码 代码优先:就是先写代码,然后根据代码去生成数据库结构. ...

  3. Django单表操作

    一.数据库相关设置 配置ORM的loggers日志: # 配置ORM的loggers日志 LOGGING = { 'version': 1, 'disable_existing_loggers': F ...

  4. Python学习---Django的基础操作180116

    Django创建数据库操作 django流程之model实例 settigs.py:更改Django2.0.1的配置,更新为之前的路径配置 'DIRS': [os.path.join(BASE_DIR ...

  5. Python之MySQL库表操作

    一:库操作 1.1 增 # 语法 # create database 库名 default charset utf8; create database db1 default charset utf8 ...

  6. $Django 多表操作(增删改查,基于双下划线,对象的查询) 在Python脚本中调用Django环境

    在Python脚本中调用Django环境. import osif __name__ == '__main__': os.environ.setdefault("DJANGO_SETTING ...

  7. Django分表操作、聚合及FQ方法

    聚合 aggregate(*args, **kwargs) # 计算所有图书的平均价格 from django.db.models import Avg Book.objects.all().aggr ...

  8. Django多表操作

    多表创建 创建模型 下面通过一个简单的图书管理系统,来阐述多表的创建和查询操作 在视图函数里里定义如下代码 from django.db import models class Book(models ...

  9. django单表操作,增、删、改、查

    一.实现:增.删.改.查 1.获取所有数据显示在页面上 model.Classes.object.all(),拿到数据后,渲染给前端;前端通过for循环的方式,取出数据. 目的:通过classes(班 ...

  10. django单表操作 增 删 改 查

    一.实现:增.删.改.查 1.获取所有数据显示在页面上 model.Classes.object.all(),拿到数据后,渲染给前端;前端通过for循环的方式,取出数据. 目的:通过classes(班 ...

随机推荐

  1. 查找nginx安装的路径以及相关安装操作命令

    查找nginx安装的路径以及相关安装操作命令 Linux环境下,怎么确定Nginx是以那个config文件启动的? [root@localhost ~]# ps -ef | grep nginxroo ...

  2. MongoDB ----基于分布式文件存储的数据库

    参考: http://www.cnblogs.com/huangxincheng/category/355399.html http://www.cnblogs.com/daizhj/category ...

  3. nohup 命令(设置后台进程): appending output to ‘nohup.out’ 问题

    一.Linux 下使用 nohup Unix/Linux下一般比如想让某个程序在后台运行,很多都是使用 & 在程序结尾来让程序自动运行. 比如我们要运行weblogic在后台:./startW ...

  4. Linux学习笔记之Linux Centos关闭防火墙

    # Centos6.x /etc/init.d/iptables stop chkconfig iptables off sed -i 's/SELINUX=enforcing/SELINUX=dis ...

  5. 03: zabbix API接口 对 主机、主机组、模板、应用集、监控项、触发器等增删改查

    目录:Django其他篇 01: 安装zabbix server 02:zabbix-agent安装配置 及 web界面管理 03: zabbix API接口 对 主机.主机组.模板.应用集.监控项. ...

  6. HTML5交互性图表库

    官网链接:https://www.hcharts.cn/ 出品公司链接:https://jianshukeji.com/ Highcharts Highstock highmaps

  7. 20145205 武钰 《网络对抗》Exp8 Web基础

    一点题外话 本次实验我三号完成的,由于一些原因吧,一直没发博客,拖到了现在,这里说就是评判一下自己的懒惰. 实验后问题回答 (1)什么是表单 表单在网页中主要负责数据采集功能. 一个表单有三个基本组成 ...

  8. 20135234mqy-——信息安全系统设计基础第二周学习总结

    Linux基础 1.Linux命令 command [options] [arguments] //中括号代表是可选的,即有些命令不需要选项也不需要参数 选项(options)或参数(argument ...

  9. 2018-2019-1 1723《程序设计与数据结构》第3&4周作业 总结

    作业要求 第三周作业: 提交情况如图: 第四周作业: 提交情况如图: 作业问题 1.问题总结方面希望大家的解决过程不要完全复制百度出来的或者其他博客的内容.因为很明显,没有自己的思考过程.可以先把参考 ...

  10. Large Division(大数)题解

    Given two integers, a and b, you should check whether a is divisible by b or not. We know that an in ...