django ORM CRUD
一.增加数据-Create
1.类名.objects.create(属性=值,属性=值)
Myomodel.objects.create(name="TeacherCang",age=)
2.d={"属性":"值"} obj=类名(**d) obj.save()
d={"name":"Money","age":}
obj=Myomodel(**d)
obj.save()
3.obj=类名() obj.属性=值 obj.save()
obj=Myomodel()
obj.name="Child"
obj.age=
obj.save()
二.删除数据-Delete
1.单个删除:类名.objects.get(属性=值).delete()
Myomodel.objects.get(id=).delete()
2.批量删除:类名.objects.filter(条件).delete()
Myomodel.objects.filter(age__lt=).delete()
三.修改数据-Update
1.单个修改:查 改 存
obj=Myomodel.objects.get(id=)
obj.name="xiugai"
obj.save()
2.批量修改:类名.objects.filter(条件).update(属性=值)
Myomodel.objects.filter(name="money").update(name="amaoagou")
四.查询数据-Retrieve
Myomodel.objects.all()#<QuerySet [<Myomodel: Myomodel object ()>]>Myomodel.objects.values()#<QuerySet [{'id': , 'name': 'xiugai', 'age': }]>Myomodel.objects.values('id','age')#<QuerySet [{'id': , 'age': }]>Myomodel.objects.values_list()#<QuerySet [(, 'xiugai', )]>Myomodel.objects.values_list('name')#<QuerySet [('xiugai',), ('Jerry',)]>Myomodel.objects.filter(name="amaoagou")#<QuerySet [<Myomodel: Myomodel object ()>]>
查询:过滤查询:类名.objects.filter(属性__查询谓词=值)#此处是双下划线
查询谓词:
1.exact 等值查询
2.contains 模糊查询,相当于like "%xx%"
3.in 模糊查询
4.gt 大于
5.lt 小于
6.gte 大于等于
7.lte 小于等于
8.startswith 以...开始,相当于like "x%"
9.endwith 以...结束,相当于like "%x"
10.range 相当于between and
11.regex 正则表达式匹配
Myomodel.objects.filter(name__startswith="Kai")#<QuerySet [<Myomodel: Myomodel object ()>]>Myomodel.objects.filter(name__contains="cher")#<QuerySet [<Myomodel: Myomodel object ()>]>
查询:条件取反:类名.objects.exclude(条件)
Myomodel.objects.exclude(name__contains="cher")#<QuerySet [<Myomodel: Myomodel object (1)>]>
查询:排序查询:类名.objects.order_by(条件)
默认是升序,字段名前加“-”即可降序排列
Myomodel.objects.order_by('age').values_list('age')
#<QuerySet [(,), (,), (,), (,), (,), (,), (,), (,), (,)]>Myomodel.objects.order_by('-age').values_list('age')
# < QuerySet[(,), (,), (,), (,), (,), (,), (,), (,), (,)] >Myomodel.objects.order_by('-age','-id').values_list('age','id')
#<QuerySet [(, ), (, ), (, ), (, ), (, ), (, ), (, ), (, ), (, )]>
只查询一条:类名.objects.get(条件)
Myomodel.objects.get(id=)#Myomodel object ()
获取查询数量
Myomodel.objects.filter(name="TeacherCang").count()#
聚合查询
from django.db.models import Avg,Sum,Count,Max,Min
.........................
Myomodel.objects.aggregate(age=Avg('age'))
Myomodel.objects.aggregate(age=Sum('age'))
Myomodel.objects.aggregate(age=Count('age'))
Myomodel.objects.aggregate(age=Max('age'))
Myomodel.objects.aggregate(age=Min('age'))
django ORM CRUD的更多相关文章
- django ORM的总结
1.django分表的方案: https://mp.weixin.qq.com/s?__biz=MjM5NjA3Nzk3Ng==&mid=2648154502&idx=1& ...
- django orm总结[转载]
django orm总结[转载] 转载地址: http://www.cnblogs.com/linjiqin/archive/2014/07/01/3817954.html 目录1.1.1 生成查询1 ...
- Django ORM - 001 - 外键表查询主表信息
开始用Django做web开发,我想大家都会遇到同样的问题,那就是如何高效快速的查询需要的数据,MVC都很简单,但是ORM折腾起来就有些费时间,我准备好好研究下Django ORM,所以会有一个系列的 ...
- Django ORM 中的批量操作
Django ORM 中的批量操作 在Hibenate中,通过批量提交SQL操作,部分地实现了数据库的批量操作.但在Django的ORM中的批量操作却要完美得多,真是一个惊喜. 数据模型定义 首先,定 ...
- Django ORM 查询管理器
Django ORM 查询管理器 ORM 查询管理器 对于 ORM 定义: 对象关系映射, Object Relational Mapping, ORM, 是一种程序设计技术,用于实现面向对象编程语言 ...
- Django ORM模型的一点体会
作者:Vamei 出处:http://www.cnblogs.com/vamei 严禁转载. 使用Python的Django模型的话,一般都会用它自带的ORM(Object-relational ma ...
- 数据库表反向生成(二) Django ORM inspectdb
在前一篇我们说了,mybatis-generator反向生成代码. 这里我们开始说如何在django中反向生成mysql model代码. 我们在展示django ORM反向生成之前,我们先说一下怎么 ...
- Django ORM那些相关操作
一般操作 https://docs.djangoproject.com/en/1.11/ref/models/querysets/ 官网文档 常用的操作 <1> all() ...
- django orm 及常用参数
一些说明: 表myapp_person的名称是自动生成的,如果你要自定义表名,需要在model的Meta类中指定 db_table 参数,强烈建议使用小写表名,特别是使用MySQL作为后端数据库时. ...
随机推荐
- ping不通服务器的解决方法
参考腾讯云的解决办法: https://cloud.tencent.com/document/product/213/14639#CheckOSSetting 我的服务器是aws的, 解决方法大同小异 ...
- vue学习面向对象,在项目中怎么用呢?
面向对象感觉很牛逼,可是在项目中怎么用呢? 我至今见到的用法,写了一个用户对象. 效果:只要执行了new User(userInfo)就会在cookie,localStorage存放数据. 所以最简单 ...
- dns攻击包代码实现
博客地址:http://home.cnblogs.com/u/zengjianrong/ 代码没有做好精简,有些多余的没有删去,因为博主太懒了哈哈 #include <stdio.h> # ...
- 详解XOR(异或)运算加密
逻辑运算之中,除了 AND 和 OR,还有一种 XOR 运算,中文称为"异或运算".它的定义是:两个值相同时,返回false,否则返回true.也就是说,XOR可以用来判断两个值是 ...
- 想让自己的项目6666,可是 Chrome 不答应!
读万卷书,行万里路!有的技能可以从书里学会,有的技能却需要在实战中打怪升级慢慢掌握,今天就来和大家聊一个很多小伙伴经常遇到的问题. 缘起 有人向松哥反映,在搭建微服务分布式配置中心 Spring Cl ...
- spring-security.xml——安全性框架配置文件
<?xml version="1.0" encoding="UTF-8"?><beans:beans xmlns="http://w ...
- js,获取字符串中存在中文的个数
var RespMemo='1231231617440C01 心存正义 10'; //定义字符串 re = /[\u4E00-\u9FA5]/g; //测试中文字符的正则 var ...
- java lambda表达式检查list集合是否存在某个值
import java.util.ArrayList; import java.util.List; import java.util.stream.Collectors; public class ...
- CDH6.1.1阿里云安装实践
概念介绍 CDH概览 CDH是Apache Hadoop和相关项目的最完整.最受测试和最流行的发行版.CDH提供Hadoop的核心元素-可伸缩存储和分布式计算-以及基于web的用户界面和重要的企业功能 ...
- 【Tomcat】Web应用的目录结构
创建时间:6.14 Web应用的目录结构 .xml文件不用自己写,抄头抄尾就可以 (别人的) (抄头抄尾) *注意:WEB-INF目录是受保护的,外界不能直接访问 如果访问WEB-INF目录下的htm ...