博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
orm单表操作
阅读量:6070 次
发布时间:2019-06-20

本文共 2634 字,大约阅读时间需要 8 分钟。

1.增加数据

from app import models//方式一book=models.Book.objects.create(name='红楼梦',price=23.8,publish='人民出版社',author='曹雪芹',create_data='2018-09-17')//方式二book=models.Book(name='水浒传',price=99.8,publish='老男孩出版社',author='施耐庵',create_data='2018-08-08')book.save()

2.删除数据

from app import models//方式一ret=models.Book.objects.filter(name='西游记').delete()//方式二ret = models.Book.objects.filter(name='西游记').first()ret.delete()

3.修改数据

ret=models.Book.objects.filter(name='西游记').update(price=20.9)#对象修改(没有update方法,但是可以用save来修改)book = models.Book.objects.filter(name='西游记').first()book.price=89book.save()

4.查询数据

<1> all(): 查询所有结果
models.Book.objects.all()
<2> filter(**kwargs): 它包含了与所给筛选条件相匹配的对象(与SQL语句中的where很像)
models.Book.objects.filter(name='西游记').first()
<3> get(**kwargs): 返回与所给筛选条件相匹配的对象,返回结果有且只有一个,如果符合筛选条件的对象超过一个或者没有都会抛出错误。
ret=models.Book.objects.get(name='红楼梦')ret=models.Book.objects.get(id=1)
<4> exclude(**kwargs): 它包含了与所给筛选条件不匹配的对象
msg = models.Book.objects.filter(name='龙珠').exists()
<5> order_by(*field): 对查询结果排序('-id')
ret=models.Book.objects.all().order_by('price').filter(name='西游记')
<6> reverse(): 对查询结果反向排序
ret=models.Book.objects.all().order_by('price'). reverse().filter(name='西游记')
<7> count(): 返回数据库中匹配查询(QuerySet)的对象数量。
ret=models.Book.objects.all().count()
<8> first(): 返回第一条记录
msg = models.Book.objects.filter(name='三国').first()
<9> last(): 返回最后一条记录
msg = models.Book.objects.filter(name='三国').last()
<10> exists(): 如果QuerySet包含数据,就返回True,否则返回False
msg = models.Book.objects.filter(name='龙珠').exists()
<11> values(*field): 返回一个ValueQuerySet——一个特殊的QuerySet,运行后得到的并不是一系列model的实例化对象,而是一个可迭代的字典序列
ret=models.Book.objects.all().values('name').distinct()
<12> values_list(*field): 它与values()非常相似,它返回的是一个元组序列,values返回的是一个字典序列
<13> distinct(): 从返回结果中剔除重复纪录

5.模糊查询数据

1.大于price__gt(查询价格大于89 的书)
ret=models.Book.objects.filter(price__gt='89')
2.小于price__lt(查询价格小于89 的书)
ret=models.Book.objects.filter(price__lt='89')
3.小于等于price__lte
ret=models.Book.objects.filter(price__lte='89')
4.大于等于price__gte
ret = models.Book.objects.filter(price__gte='89')
5.在某个列表中__in
ret=models.Book.objects.filter(price__in=['23.8','89','100'])
6.在某个范围中__range
ret=models.Book.objects.filter(price__range=[50,100])
7.查询名字有'红'的书 __contains (类似于SQL中的"%红%")
ret=models.Book.objects.filter(name__contains='红')
8.查询名字带p的书,忽略大小写 __icontains
ret=models.Book.objects.filter(name__icontains='P')
9.以XX开头 __startswith
ret=models.Book.objects.filter(name__startswith='红')
10.以XX结尾 __endswith
ret=models.Book.objects.filter(name__endswith='梦')
11.按年查询 __year
ret=models.Book.objects.filter(create_data__year='2017')

转载于:https://www.cnblogs.com/jianhaozhou/p/9948913.html

你可能感兴趣的文章
理解B树索引
查看>>
vi编辑器的命令集合
查看>>
Mysql利用binlog恢复数据
查看>>
解决 Windows启动时要求验证
查看>>
我的友情链接
查看>>
用yum安装mariadb
查看>>
一点IT"边缘化"的人的思考
查看>>
Gallery循环滑动
查看>>
Sql与C#中日期格式转换总结
查看>>
iOS开发流程总结
查看>>
hadoop datanode 启动出错
查看>>
js颜色拾取器
查看>>
IDEA使用(1)intellIJ idea 配置 svn
查看>>
Thread Safety in Java(java中的线程安全)
查看>>
WPF 降低.net framework到4.0
查看>>
数据管理DMS 全量SQL诊断:你的SQL是健康的蓝色,还是危险的红色?
查看>>
搭建一个通用的脚手架
查看>>
开年巨制!千人千面回放技术让你“看到”Flutter用户侧问题
查看>>
开源磁盘加密软件VeraCrypt教程
查看>>
本地vs云:大数据厮杀的最终幸存者会是谁?
查看>>