django的model操作汇整详解
作者:bainianminguo 发布时间:2022-05-16 03:59:46
标签:django,model,操作
单表操作
增加数据
auther_obj = {"auther_name":"崔皓然","auther_age":1}
models.auther.objects.create(
**auther_obj
)
models.auther.objects.create(
auther_name="周雍博",
auther_age=4
)
obj = models.auther(
auther_name="崔洪艳",
auther_age=29
)
obj.save()
obj = models.auther(
auther_name = "王仙枝",
auther_age = "50"
)
obj.save()
删除数据
models.auther.objects.filter(auther_name="崔洪艳")[0].delete()
一对多操作
增加数据
a_obj = models.auther.objects.get(id=1)
models.book.objects.create(
book_name = "python课程1",
book_price = 12,
book_auther = a_obj
)
a_obj = models.auther.objects.get(id=5)
models.book.objects.create(
book_name = "java课程1",
book_price = 13,
book_auther_id = a_obj.id
)
a_obj = models.auther.objects.get(id=2)
book_dict = {
"book_name":"python课程2",
"book_price":14,
"book_auther_id":a_obj.id
}
obj = models.book.objects.create(
**book_dict
)
a_obj = models.auther.objects.get(id=4)
book_dict = {
"book_name":"java课程2",
"book_price":15,
"book_auther":a_obj
}
models.book.objects.create(
**book_dict
)
一对多正向查询
# 查询id为2的书的所有作者的信息
obj = models.book.objects.get(id=2)
print(obj.book_auther.auther_name)
print(obj.book_auther.auther_age)
obj = models.book.objects.filter(id=2).values("book_name","book_price","book_auther__id","book_auther__auther_name","book_auther__auther_age")
print(obj)
# 查询id为2的作者的出版的书
obj = models.book.objects.filter(book_auther_id=2).values("book_name","book_price","book_auther__id","book_auther__auther_name","book_auther__auther_age")
print(obj)
obj = models.book.objects.get(book_auther_id=2)
print(obj.book_auther.auther_age)
print(obj.book_auther.auther_name)
print(obj.book_name)
一对多反向查询
# 查看出版社出版的书
obj = models.auther.objects.filter(id=2).values("auther_name","auther_age","book__book_name")
print(obj)
obj = models.auther.objects.get(id=2).book_set.values("book_name","book_price","book_auther__id","book_auther__auther_name","book_auther__auther_age")
print(obj)
多对多操作
增加数据
b1 = models.book.objects.get(id=1)
b2 = models.book.objects.get(id=2)
b4 = models.book.objects.get(id=4)
b5 = models.book.objects.get(id=5)
models.publish.objects.get(id=1).publish_book.add(
b1,b2
)
book_list = [b1,b2]
models.publish.objects.get(id=2).publish_book.add(
*book_list
)
更新数据
book_list = [b1,b2,b4,b5]
models.publish.objects.get(id=1).publish_book.set(book_list)
移除数据
models.publish.objects.get(id=1).publish_book.remove(b1)
book_list = [b2, ]
models.publish.objects.get(id=1).publish_book.remove(*book_list)
正向查询
obj = models.publish.objects.get(id=1).publish_book.values("book_name","publish__publish_name")
print(obj)
obj = models.publish.objects.filter(id=1).values("publish_name","publish_book__book_name")
print(obj)
反向添加数据
p1 = models.publish.objects.get(id=1)
p2 = models.publish.objects.get(id=2)
p3 = models.publish.objects.get(id=3)
b1.publish_set.add(p1,p2,p3)
反向删除数据
b1.publish_set.remove(p1)
反向更新数据,把remove替换为set就可以了
反向查询
obj = models.book.objects.get(id=1).publish_set.values("publish_name","publish_book__book_name")
model中多表关系和参数
多对多
一对一
model操作
来源:https://www.cnblogs.com/bainianminguo/p/9351936.html


猜你喜欢
- 1 为什么要分库分表物理服务机的CPU、内存、存储设备、连接数等资源有限,某个时段大量连接同时执行操作,会导致数据库在处理上遇到性能瓶颈。为
- 基本介绍pandas是Python数据挖掘、数据分析中常用的库。而DataFrame生成excel中的sheet表,以及在excel中增加s
- 背景:这个库的安装不是像其他的一样的直接使用 pip install XXX的形式,而是使用原始的Git方式1、apex这是NVIDIA开发
- 淘宝招聘的一个css题目:css样式控制div水平垂直居中方法;<!DOCTYPE html PUBLIC "-//W3C/
- 背景简介别踩白板这个游戏相信大家都玩过,这个是基于HTML5打造的简单小游戏,在PC端和移动端都能够运行,适应多种平台,今天我们使用原生JS
- MySQL在5.1引入了一个rename database操作,但在MySQL5.1.23后又不支持这个命令。可以说是一个实验性的功能,没有
- 本文实例为大家分享了java正则表达式工具类的具体代码,供大家参考,具体内容如下import com.google.common.base.
- 本文实例讲述了php获取给定日期相差天数的方法。分享给大家供大家参考,具体如下:方法一:<?phpfunction count_day
- 一.介绍多表查询就是同时查询两个或两个以上的表,因为有的时候用户在查看数据的时候,需要显示的数据来自多张表.多表查询有以下分类:交叉连接查询
- 本文目的是由浅入深地介绍python装饰器原理装饰器(Decorators)是 Python 的一个重要部分其功能是,在不修改原函数(类)定
- 🚀 文章简介 :本篇文章的实战部分中主要使用到了 MediaPipe 与 OpenCv 两个库,实现了隔空操作的效果,主要有**隔空操作鼠标
- 本文实例讲述了Python通过递归遍历出集合中所有元素的方法。分享给大家供大家参考。具体实现方法如下:''''
- 首先进入python官网https://www.python.org/通过Downloads选项,选择需要的版本进行下载,此处我以 Wind
- 前言做前端开发几年,在项目中用到数组去重的机会倒不是很多,但是在面试的时候却经常被问到,个人理解,这道题真正考的是对JavaScript的基
- 最近做的一个B/S项目,在打印时采用了在IE中嵌入.net winform控件和XML结合的方式(参见http://www.yesky.co
- 本文实例讲述了python二分法查找算法实现方法。分享给大家供大家参考,具体如下:二分法查找二分查找又称折半查找,优点是比较次数少,查找速度
- 概念Slice切片是对底层数组Array的封装,在内存中的存储本质就是数组,体现为连续的内存块,Go语言中的数组定义之后,长度就已经固定了,
- 1. 准备工作首先编写getHtml函数,传入markdown文本字符串,这里使用fs读取markdown文件内容,返回值是转换过后的字符串
- 问题你想读写一个CSV格式的文件。解决方案对于大多数的CSV格式的数据读写问题,都可以使用 csv 库。、例如,假设你在一个名叫stocks
- 使用Keras如果要使用大规模数据集对网络进行训练,就没办法先加载进内存再从内存直接传到显存了,除了使用Sequence类以外,还可以使用迭