django第9天

models类


class Book(Model):
id = AutoField(primary_key=True)
name = CharField(max_length=20)
price = DecimalField(max_digits=5,decimal_places=2)
publish_date = DateField(auto_now_add=True)
publish = ForeignKey(to="Publish",to_field='id') author = ManyToManyField(to="Author")#多对多关系字段,该字段不会在表中形成字段,是创建关系表的字段,会找到两个表的主键,进行建表 类属性id,name是为了在数据库中建立表字段使用,是代理类(autofield,charfield....)的对象
外键:
publish = Foreignkey(to = 'Publish',to_field='id')
Book类对象的publish属性对应的是Publish表的一个对象,
也就是说通过Book().publish得到的对象包含了关系表的对应记录
orm将publish属性加后缀__id(to_field字段)作为book表的一个字段
使用了外键后,需要先创建好Publish表才能插入Book表数据

多表增删改

一对多关系

#一个出版社对应多本书,
#书依赖于出版社
#增先需要增出版社 #book: name,price,publish_date,publish
#author:name, author_detail
#authordetail:age,telephone,info
#publish:name,addr 1.增
#通过字段
publish = Publish.objects.create(
name = "老男孩出版社",addr = "上海")
Book.objects.create(name = "python",price=66.66,publish_date='1990-1-2',publish_id = publish.id) publish = Publish.objects.create(name="oldboy",addr="上海")
book = Book.objects.create(name="python",price=66.66,publish_date='1999-01-01',publish_id = publish.id) #通过属性
p1 = Publish.objects.first()
Book.objects.create(name="go",price=88.88,publish_date = '1970-1-31',publish = p1) publish = Publish.objects.first()
book = Book.objects.create(name="go",price=55.55,publish_date='1998-01-01',publish = publish) 2.删
#单表删除
book = Book.objects.last().delete()
# book = Book.objects.first().delete()
#book是一,删除时就是删除单条记录
#级联删除
Publish.objects.first().delete()
# Publish.objects.all().delete()
#publish是多,删除时,将关联的book都删除掉 3.改
book的出版社修改必须为已存在的出版社 publish = Publish.objects.create(name='mygirl',addr='北京')
Book.objects.filter(id = 3).update(publish = publish)#属性修改
Book.objects.filter(id = 3).update(publish_id = publish.id)#字段修改

一对一关系

通过外键所在表决定依赖关系

#book: name,price,publish_date,publish
#author:name, author_detail
#authordetail:age,telephone,info
#publish:name,addr
author ---- author_detail 增:
遵循操作顺序
先增author_detail表
author_detail = AuthorDetail.objects.create(age=18,telephone=13588888888,info='真有钱')
Author.objects.create(name = 'zb',author_detail = author_detail) 删
# author_detail = AuthorDetail.objects.create(age=18,telephone=12311112222,info='真的渣')
# Author.objects.create(name='xzh',author_detail = author_detail) # author_detail = AuthorDetail.objects.create(age = 17,telephone = 32122221111,info='真的2')
# Author.objects.create(name = 'xhz',author_detail_id = author_detail.id) # Author.objects.first().delete()#删除作者,信息不会被清除,依赖明细表
# AuthorDetail.objects.last().delete()#删除作者明细,作者会被删除,作者明细表被依赖表 改:1对1一般不考虑关联字段

多对多关系

1.多对多关系存在关系表,关系表建议采用manytomanyfield字段处理
book表与author表,多对多 #book: name,price,publish_date,publish
#author:name, author_detail 通过关系表字段存在的类的对象获取关系表
关系表:book.author 增:
为book添加作者的主键或对象们
book.author.add(*args)
#对象
# b1 = Book.objects.first()
# a1 = Author.objects.first()
# b1.author.add(a1)
#主键
# b2 = Book.objects.last()
# a2 = Author.objects.last()
# b2.author.add(a2.id) '''
添加多条
a1 = Author.objects.first()
b2 = Book.objects.last()
a2 = Author.objects.last()
b2.author.add(a1,a2)
''' 删:删除书籍已有作者的主键或对象们
book.author.remove(*args)
# b2 = Book.objects.last()
# a2 = Author.objects.last()
# b2.author.remove(a2.id) 改:清空并添加作者的主键或对象|设置作者的主键或对象形式的列表
#book对象,不能是列表
#清空book对应作者们的所有对应关系
book.author.clear()
book.author.add(*args)
#注:清空会将id清除,也就说原book对象的id会变更 book.author.set([*args])
#id不变,原作者id,不在列表中的清空,在列表中保留,
a1 = Author.objects.first() book = Book.objects.last()
book.author.set([a1.id]) # book = Book.objects.last()
# print(book)
# book.author.clear()

跨表查询规则

1.正向逆向概念:
从存放外键的表到关系表叫正向查询反之称为逆向查询
2.正向查询通过外键属性名进行跨表查询
3.逆向查询通过关联表对应类名小写进行跨表查询

基于对象的跨表查询

在跨表查询的规则上,跨表查询的结果为多条数据时需要在字段后添加_set

一对一
author = Author.objects.first()
#正向通过字段名author_detail
author_detail =author.author_detail #逆向获取作者对象,通过表名小写
author = author_detail.author
'''
author = Author.objects.first()
author_d = author.author_detail
print(author_d.info) author_d = AuthorDetail.objects.all()[1]
a1 = author_d.author
print(a1.name) ''' #book: name,price,publish_date,publish
#author:name, author_detail
#authordetail:age,telephone,info
#publish:name,addr 一对多
正向:
book = Book.objects.first()
publish = book.publish #book = Book.objects.first()
#publish = book.publish
#print(publish.name,publish.addr)
逆向:
publish = Publish.objects.first()
book_list = publish.book_set.all() #publish = Publish.objects.all()[1]
#book_list = publish.book_set.all()
#print(book_list) 多对多
正向:
book = Book.objects.first()
author_list = book.author.all()
'''
book = Book.objects.first()
print(book.name)
author_list = book.author.all()
'''
逆向:
author = Author.objects.first()
book_list = author.book_set.all() #author = Author.objects.first()
#print(author.name)
#book_list = author.book_set.all()
#print(book_list[0].name,book_list[1].name) 多级跨表
某作者出版的第一本书的出版社名字
author = Author.objects.filter(name ='xzh').first()
book = author.book_set.first()
book.publish.name

基于下划线的跨表查询

满足跨表查询规则
filter方法与values方法支持__查询规则 # 案例 # 两表关联:查询所有小于18岁作者的名字与实际年龄 '''
authors_dic = Author.objects.filter(author_detail__age__lt=18).values('name', 'author_detail__age')
print(authors_dic)
''' # 多表关联:查询出版社在上海的出版过的所有书的 作者姓名、作者电话、具体出版社名 的相关信息
info_dic = Book.objects.filter(publish__address__contains="上海").values('author__name', 'author__author_detail__telephone', 'publish__name')

django第9天(多表操作)的更多相关文章

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

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

  2. Django模型层之单表操作

    Django模型层之单表操作 一 .ORM简介 我们在使用Django框架开发web应用的过程中,不可避免地会涉及到数据的管理操作(如增.删.改.查),而一旦谈到数据的管理操作,就需要用到数据库管理软 ...

  3. 第五章、Django之模型层---单表操作

    目录 第五章.Django之模型层---单表操作 一.ORM查询 二.Django测试环境搭建 三.单表查询 1. 增 2. 改 3. 删 4. 查 第五章.Django之模型层---单表操作 一.O ...

  4. Django之模型层:表操作

    目录 Django之模型层:表操作 一.ORM简介 django测试环境搭建 Django终端打印SQL语句 二 单表操作 2.1 按步骤创建表 2.2记录 三.多表操作 1 创建模型 2 添加.删除 ...

  5. day 70 Django基础五之django模型层(二)多表操作

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

  6. day 69 Django基础五之django模型层(一)单表操作

    Django基础五之django模型层(一)单表操作   本节目录 一 ORM简介 二 单表操作 三 章节作业 四 xxx 一 ORM简介 MVC或者MVC框架中包括一个重要的部分,就是ORM,它实现 ...

  7. day 56 Django基础五之django模型层(二)多表操作

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

  8. day 55 Django基础五之django模型层(一)单表操作

      Django基础五之django模型层(一)单表操作   本节目录 一 ORM简介 二 单表操作 三 章节作业 四 xxx 一 ORM简介 MVC或者MVC框架中包括一个重要的部分,就是ORM,它 ...

  9. Django框架06 /orm多表操作

    Django框架06 /orm多表操作 目录 Django框架06 /orm多表操作 1. admin相关操作 2. 创建模型 3. 增加 4. 删除 5. 修改 6. 基于对象的跨表查询 7. 基于 ...

  10. Django框架05 /orm单表操作

    Django框架05 /orm单表操作 目录 Django框架05 /orm单表操作 1. orm使用流程 2. orm字段 3. orm参数 4. orm单表简单增/删/改 5. orm单表查询 5 ...

随机推荐

  1. 并发编程协程(Coroutine)之Gevent

    并发编程协程之Gevent Gevent官网文档地址:http://www.gevent.org/contents.html 基本概念 我们通常所说的协程Coroutine其实是corporate r ...

  2. laravel使用swoole

    参考 参考2 另外主要用到artisan 首先创建SwooleCommand.php <?php namespace App\Console\Commands; use App\Http\Con ...

  3. OS 内存泄漏 导致 整个aix主机block

    问题 aix 主机 1.数据库主机使用vmstat 监控,隔几分钟 就是block 爆满. cpu 没有瓶颈,I/O 显示本地磁盘hdisk0和hdisk 1 是爆满. vmstat 同时显示大量pa ...

  4. P1281 书的复制

    题目描述 现在要把m本有顺序的书分给k给人复制(抄写),每一个人的抄写速度都一样,一本书不允许给两个(或以上)的人抄写,分给每一个人的书,必须是连续的,比如不能把第一.第三.第四本书给同一个人抄写. ...

  5. hihocoder1829 Tomb Raider

    思路: 暴力枚举. 实现: #include <iostream> #include <set> #include <vector> using namespace ...

  6. Azure 项目构建 – 部署 Drupal 网站

    通过完整流程详细介绍了如何通过 Azure Web 应用. MySQL DB on Azure 等服务在 Azure 平台上快速搭建 Drupal 服务器,并将其连接到 MySQL 数据库. 此系列的 ...

  7. Flask应用运行流程

    当我们运行项目后,Flask内部都经历了什么 1.app.run()启动项目,ctrl点进源码 app.py: 1)执行了run_simple() 2)注意第三个参数,这里是Flask实例化的对象,在 ...

  8. NumPy库的基本使用

    一.介绍 ——NumPy库是高性能科学计算和数据分析的基础包,它是Pandas及其它各种工具的基础 ——NumPy里的ndarry多维数组对象,与列表的区别是: - 数组对象内的元素类型必须一样 - ...

  9. vue使用echarts可视化图形插件

    1.安装echarts:  cnpm/npm i echarts -S 2.main.js中   import echarts from 'echart'    Vue.prototype.$echa ...

  10. 100行代码让您学会JavaScript原生的Proxy设计模式

    面向对象设计里的设计模式之Proxy(代理)模式,相信很多朋友已经很熟悉了.比如我之前写过代理模式在Java中实现的两篇文章: Java代理设计模式(Proxy)的四种具体实现:静态代理和动态代理 J ...