day09 orm查询优化相关
day09 orm查询优化相关
今日内容概要
- orm字段相关补充
- orm查询优化相关
- orm事务操作
- 图书管理系统练习
今日内容详细
orm事务操作
"""
事务:ACID
A原子性
C一致性
I独立性
D持久性
start transaction
...
rollback
commit
"""
from django.db import transaction
# 事务
# 买一本 跟jason学Linux 书
# 在数据库层面要做的事儿
# 1. 创建一条订单数据
# 2. 去产品表 将卖出数+1, 库存数-1
from django.db.models import F
# 开启事务处理
try:
with transaction.atomic():
# 创建一条订单数据
models.Book.objects.create(num="110110111", product_id=1, count=1)
# 能执行成功
models.Book.objects.filter(id=1).update(kucun=F("kucun") - 1, maichu=F("maichu") + 1)
except Exception as e:
print(e)
transaction.rollback() # 回滚
transaction.commit() # 提交
orm常用字段
# verbose_name 中文标识
AutoField() # 专门用于主键
"""需要指定primary key参数"""
CharField()
"""需要指定max_length参数 varchar()"""
IntegerField() # 整形
DecimalField() # 浮点型
DateField()
DateTimeField()
"""
auto_now 每次更新数据记录的时候会更新该字段
auto_now_add 创建数据记录的时候会把当前时间添加到数据库
"""
BooleanField() # 布尔值类型
"""
传布尔值 存0或1
is_delete = models.BooleanField()
is_alive = models.BooleanField()
is_buy = models.BooleanField()
"""
TextField() # 文本类型
"""
专门用于存储大段文本数据
比如文章内容...
"""
EmailField() # 邮箱类型
FileField()
- 字符串,路径保存在数据库,文件上传到指定目录
- upload_to = "" 上传文件的保存路径
DecimalField(Field)
- 10进制小数
- 参数:
max_digits,小数总长度
decimal_places,小数位长度
"""自定义字段:为了防止django版本与最新的数据库产生差异"""
class MyCharField(models.Field):
def __init__(self, max_length, *args, **kwargs):
self.max_length = max_length
super().__init__(max_length=max_length, *args, **kwargs)
def db_type(self, connection):
return 'char(%s)' % self.max_length
# 重要参数
null = True
default = None
unique 如果设置为unique=True 则该字段在此表中必须是唯一的 。
db_index 如果db_index=True 则代表着为此字段设置索引。
# 外键字段
to、to_field、on_delete、related_name(给外键字段起别名 用于正反向)
db_constraint
"""自行总结django1.X与django2.X|3.X外键字段使用的区别"""
orm查询优化
only与defer
select_related与prefetch_related
1、在ORM语句中 默认所有的查询都是惰性查询
res = models.Book.objects.all()
res1 = models.Book.objects.filter(pk=1)
2、only与defer
获取指定字段对应的数据 并且封装成字典
res = models.Book.objects.values('title')
for d in res:
print(d,type(d))
print(d.get('title'))
获取指定字段对应的数据 并且封装成对象
res = models.Book.objects.only('title')
for obj in res:
print(obj.title)
print(obj.price)
print(obj.publish_time)
"""
对象点击only括号内填写的字段名称不会再走数据库查询
但是点击括号内不存在的字段名称则每次都会走数据库查询
"""
# defer
res = models.Book.objects.defer('title')
for obj in res:
print(obj.price)
"""
对象点击defer括号内填写的字段名称会再走数据库查询
但是点击括号内不存在的字段名称则每次都不会走数据库查询
"""
select_related
res = models.Book.objects.filter(pk=3).first()
print(res.publish.name)
"""select_related括号内只能放外键字段 并且不支持多对多外键字段"""
3、select_related
res = models.Book.objects.select_related('publish') # 走一次数据库查询
for obj in res:
print(obj.publish.name)
"""
内部是连表操作 会将外键关联的表与当前表拼接 之后将所有的数据全部封装到数据对象中
之后对象无论查询哪个表的数据都不再走数据库查询,不能放多对多
"""
4、prefetch_related
res = models.Book.objects.prefetch_related('publish') # 走两条数据库查询
for obj in res:
print(obj.publish.name)
"""
内部是子查询操作 先查询所有的书籍数据 之后查询每本书籍数据对应的出版社数据
之后将总数据封装到数据对象中
"""
图书管理系统
表:四张表
功能:只需要实现图书的增删改查即可
界面:使用bootstrap框架
知识点:路由层 视图层 模板层 模型层全部
"""写项目的基本流程 永远都是从数据库设计开始"""
# 首页
url(r'^$', views.home,name='hm'),
# 图书展示
url(r'^book_list/', views.book_list, name='bl'),
# 图书添加
url(r'^book_add/', views.book_add, name='ba')
def home(request):
return render(request, 'home.html')
def book_list(request):
book_queryset = models.Book.objects.all()
return render(request, 'book_list.html', locals())
def book_add(request):
if request.method == 'POST':
# 获取用户上传的图书数据
title = request.POST.get('title')
price = request.POST.get('price')
publish_time = request.POST.get('publish_time')
publish_pk = request.POST.get('publish_pk')
authors_pk_list = request.POST.getlist('authors_pk_list')
'''涉及到数据的校验 暂时都不考虑 后面有现成的组件可以完成'''
book_obj = models.Book.objects.create(title=title, price=price, publish_time=publish_time, publish_id=publish_pk)
book_obj.authors.add(*authors_pk_list) # getlist获取到的是列表 而add方法只能传多个参数逗号隔开 所以使用*打散
# _url = reverse('bl')
return redirect('bl')
"""
redirect括号内支持直接写别名 能够自动反向解析
但是该功能也仅仅局限于没有无名有名分组的情况 就需要借助有reverse方法
"""
publish_queryset = models.Publish.objects.all()
author_queryset = models.Author.objects.all()
return render(request, 'book_add.html', locals())
day09 orm查询优化相关的更多相关文章
- Django ORM那些相关操作zi
Django ORM那些相关操作 一般操作 看专业的官网文档,做专业的程序员! 必知必会13条 <1> all(): 查询所有结果 <2> filter(**kwargs) ...
- Django ORM 那些相关操作
Django ORM 那些相关操作 一般操作 必知必会13条 <> all(): #查询所有的结果 <> filter(**kwargs) # 它包含了与所给筛选条件相匹配的对 ...
- orm查询优化 MTV和MVC模型 字段的chioces参数 Ajax
目录 一.ORM查询优化 1. all()查询 2. only()/defer()方法 (1)only()方法 (2)defer()方法 3. select_related()/prefetch_re ...
- Django的ORM那些相关操作
一般操作 看专业的官网文档,做专业的程序员! 必知必会13条 <> all(): 查询所有结果 <> filter(**kwargs): 它包含了与所给筛选条件相匹配的对象 & ...
- Django之ORM那些相关操作
一般操作 看专业的官网文档,做专业的程序员! 必知必会13条 <1> all(): 查询所有结果 <2> filter(**kwargs): 它包含了与所给筛选条件相匹配的对象 ...
- Django ORM那些相关操作
一般操作 https://docs.djangoproject.com/en/1.11/ref/models/querysets/ 官网文档 常用的操作 <1> all() ...
- ORM性能相关
model: 先给一个简单的表结构 from django.db import models class User(models.Model): username=models.CharField(m ...
- Django之ORM查询优化
目录 only 和 defer select_related 和 prefetch_related ORM字段参数 choices res = models.Book.objects.all() # ...
- Django框架之ORM的相关操作之分页(六)
分页是每个项目必不可少要写的一个功能,该篇文章就将记录一下使用ORM写分页的过程. 假设我们的数据库里面需要显示一些数据,而这个表中的数据大约有几千条数据,那么我们不可能将所有的数据都显示出来,那么就 ...
随机推荐
- 从零开始 DIY 智能家居 - 智能开窗器
前言 做完智慧浇水器之后对这种可以节省时间和精力的场景总有一种谜之向往(懒鬼是这样的),这次我准备做一个可以自动开窗的装置,结合之前的甲醛检测传感器就可以实现甲醛含量过高自动开窗通风,之后还可以把燃气 ...
- linux shell脚本中的开头#!/bin/bash的含义
对于linux上需要执行 的shell脚本,通常第一行的内容是 #!/bin/bash 当然有很多时候不规范的写法可以忽略掉这一句,执行起来好像也是ok,结果没什么不一样 .. 这只是因为在我们常用 ...
- linux shell 函数返回值问题(超过255)
最近再写一个shell测试的时候出现问题,函数返回值异常 用shell计算斐波那契数列数列,写了一个shell函数,然后调用的,验证的时候我只随便计算了几个数(10以内),确认结果是正确的就提交了,后 ...
- 数值的整数次方 牛客网 剑指Offer
数值的整数次方 牛客网 剑指Offer 题目描述 给定一个double类型的浮点数base和int类型的整数exponent.求base的exponent次方 class Solution: #run ...
- python3.5 安装mysqlclient
python 3.5 安装 mysqlclient 会失败 pip install mysqlclient 注意这里环境中只有python3.5 会出现一大堆红字 编译终止, error: comma ...
- hdu 2176 取(m堆)石子游戏 (裸Nim)
题意: m堆石头,每堆石头个数:a[1]....a[m]. 每次只能在一堆里取,至少取一个. 最后没石子取者负. 先取者负输出NO,先取胜胜输出YES,然后输出先取者第1次取子的所有方法.如果从有a个 ...
- 从0到1搭建自己的组件(vue-code-view)库(下)
0x00 前言 书接上文,本文将从源码功能方面讲解下 vue-code-view 组件核心逻辑,您可以了解以下内容: 动态组件的使用. codeMirror插件的使用. 单文件组件(SFC,singl ...
- swoole、swoft环境配置
一.服务器环境 1.lnmp wget http://soft.vpser.net/lnmp/lnmp1.5.tar.gz -cO lnmp1.5.tar.gz && tar zxf ...
- robotframework定位页面内Frame框架里的元素
在自动化开发中,会遇到在页面内部点开一个新的页面后,新的页面元素无法定位到的情况,如点击下图的上传图片,弹出的界面无法直接定位到: 遇到这种情况需要查看弹出界面是否是Frame框架页面:打开火狐浏览器 ...
- PTA 7-1 是否完全二叉搜索树 (30分)
PTA 7-1 是否完全二叉搜索树 (30分) 将一系列给定数字顺序插入一个初始为空的二叉搜索树(定义为左子树键值大,右子树键值小),你需要判断最后的树是否一棵完全二叉树,并且给出其层序遍历的结果. ...