python django性能_Python学习---Django下的Sql性能的测试

安装django-debug-tools

性能测试:

settings.py

INSTALLED_APPS = [

...

'app01', # 注册app

]

STATICFILES_DIRS = (os.path.join(BASE_DIR, "statics"),) # 现添加的配置,这里是元组,注意逗号

TEMPLATES = [

...

'DIRS': [os.path.join(BASE_DIR, 'templates')],

]

urls.py

from django.contrib import admin

from django.urls import path

from django.conf.urls import url

from app01 import views

from django.conf.urls import include

from django.conf import settings

urlpatterns = [

path('admin/', admin.site.urls),

url('index/', views.index)

]

if settings.DEBUG:

import debug_toolbar

urlpatterns += [

url(r'^__debug__/', include(debug_toolbar.urls)),

]

views.py

from django.shortcuts import render, redirect, HttpResponse

from app01 import models

def index(request):

v = models.U.objects.all().prefetch_related('userType')

return render(request, 'index.html', {"v": v})

templates/index.html

{% for item in v %}

{{ item.name }} {{ item.email }} {{ item.userType.caption }}

{% endfor %}

初始化数据库

python manage.py makemigrations

python manage.py migrate

页面显示;

models.U.objects.all():

models.U.objects.all().select_related(‘userType’):

models.U.objects.all().prefetch_related('userType')

性能对比:

select_related > prefetch_related > all()

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值