一 QuerySet类型

 QuerySet类型:只和orm有关,如果一涉及数据库,就会有QuerySet类型的出现。

 QuerySet切片操作:QuerySet是支持切片操作的,不过不能放负数。查询集的切片会返回一个新的查询集,不会执行查询。

 Entry.objects.all()[:5]      # (LIMIT 5)

Entry.objects.all()[5:10]    # (OFFSET 5 LIMIT 5)

 QuerySet遍历操作:

# for book  in bookList:
# print(book.title)

 可迭代对象:用于优化缓存,将QuerySet对象做成一个迭代器。iterator就是将QueSet做成一个迭代器,不能复用,只能够操作一次。这样第二次拿数据就不能从缓存中拿取数据了。

 # 优化QuerySet的缓存
bookList=Book.objects.all() # (1) exists优化
# if bookList.exists():
# print("有记录")
# (2)
# bookList = Book.objects.all().iterator()
# print(bookList)
# print(type(bookList)) # generator # for book in bookList:
# print(book.title)
# for book in bookList:
# print(book.title)

 惰性查询:使用时才会在内存中产生,一次只拿一个,哪一个丢一个。不用的时候是不会在内存中产生的。QuerySet不是使用时是不会产生sql语句的,也就是说请求查询集才会到数据库查找。主要时最大程度防止做无效的操作。

# bookList=Book.objects.all()
# for book in bookList:
# print(book) # print(bookList[1]) # if bookList:
# print("hello")

 缓存机制:第一次走完数据库过后,就不会在走第二次数据库了,而是在第一次走完数据库后,将数据放在了缓存中,这样一来第二次的时候直接就可以到数据库中拿去数据了。QuerySet对象就是那一个缓存机制。

# bookList=Book.objects.all()
# for book in bookList:
# print(book)
#
# Book.objects.create(title="linux",price=20,publish_id=1,publishDate="2012-12-12")
#
# for book in bookList:
# print(book) # bookList=Book.objects.all()
# for book in bookList:
# print(book) # print(bookList[1]) # if bookList:
# print("hello") # for book in Book.objects.all():
# print(book)
#
# for book in Book.objects.all():
# print(book)

二 中介模型

 through=‘多对多的关联表’:将那张多对多的关联表手动创建,再用through告诉orm第三张表记录已经创建,不需要在创建。

class TagLanguage(models.Model):
'''
标签语
'''
Text=models.CharField(max_length=50) # 标签文本
CreateTime=models.DateTimeField() # 标签创建的时间 class ArticleToTag(models.Model):
'''
标签和文章的关系关系表
'''
article_id=models.ForeignKey('Article') # 关联文章表
Tag_id=models.ForeignKey('TagLanguage') # 关联标签表 class Article(models.Model):
'''
文章信息
'''
article_name=models.CharField(max_length=20) # 文章名
summary=models.CharField(max_length=259) # 摘要部分
DateTime=models.DateTimeField() # 发布的时间日期
author=models.CharField(max_length=15) # 作者
randings=models.IntegerField(max_length=8) # 阅读数量
personalSite=models.ForeignKey('PersonalSite') # 与个人站点关联,以以一对多的关系关联
tagLangusges = models.ManyToManyField('TagLanguage',through='ArticleToTag')

 extra函数:django的查询语句,为了不能够对应sql语句的提供一个语句拼接。为QuerySet进行了一些修改,一边用orm,另一边用的时sql语句。

 使用格式:extra={'拿到的字段','sql语句'}。

 strftime:方法内部格式:('strftime——>sql语句',时间对象)

# 查询每一个年月出版的书籍个数
'''
sql: select date from book group by date_format(publishDate,"%Y-%m") as date ''' # ret=Book.objects.all().extra(select={"pub_year_month":"strftime('%%Y-%%m',publishDate)","isGt100":"price>100"}).values("title","pub_year_month","isGt100")
#
# print(ret) #bookList=Book.objects.all().extra(select={"pub_year_month":"strftime('%%Y',publishDate)"}).values("pub_year_month","title").annotate(c=Count("id")).values("pub_year_month","c")

 bulk_create:批量的插入数据,将实例的对下昂管放在一个列表中,然后再将列表的数据咋一次的添加进去。

批量导入数据:
for i in range(100):
Book.objects.create(title="book"+str(i),price=i*4) bookList=[]
for i in range(100):
book=Book(title="book"+str(i),price=i*4)
bookList.append(book) Book.objects.bulk_create(bookList)

三 分页模块

 Paginator米快,分页,这时django自带的一种分页模块

 导入路径:from django.core.paginator impost Paginator.

 对象的三个属性:

  count:总共数据的条数

  num_pages:能分成多少页数

  page_range:显示的页码数

 其他操作:

  page(数字):具体哪一页。

  object_list:取到对应的数据

  has_next:是否有下一页

  next_page_number:下一页

  has_previous:是否有上一页

  previous_page_number:上一页

def index(request):

    '''
批量导入数据:
for i in range(100):
Book.objects.create(title="book"+str(i),price=i*4) bookList=[]
for i in range(100):
book=Book(title="book"+str(i),price=i*4)
bookList.append(book) Book.objects.bulk_create(bookList) :param request:
:return:
'''
book_list = Book.objects.all()
paginator = Paginator(book_list, 2)
try: # paginator对象三个属性
print(paginator.count) # Paginator
print(paginator.num_pages) # 13
print(paginator.page_range) # range(1, 14) # 具体页对象
num = request.GET.get("page", 1)
num = int(num)
page = paginator.page(num)
'''
print(page.has_next()) #是否有下一页
print(page.next_page_number()) #下一页的页码
print(page.has_previous()) #是否有上一页
print(page.previous_page_number()) #上一页的页码
'''
# print("===========",page.next_page_number())
# print("===========",page.previous_page_number()) except Exception:
page=paginator.page(1) book_list = page.object_list
return render(request,"index.html",locals())

 异常处理:

  导入异常:from django.paginator import Emginator,PageNotAnInteger

    try:
print(page)
book_list = paginator.page(page)
except PageNotAnInteger:
book_list = paginator.page(1)
except EmptyPage:
book_list = paginator.page(paginator.num_pages)

 html文件实例:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<!-- 新 Bootstrap 核心 CSS 文件 -->
<link rel="stylesheet" href="//cdn.bootcss.com/bootstrap/3.3.5/css/bootstrap.min.css">
</head>
<body> <ul>
{% for book in book_list %}
<li>{{ book.title }}----------->{{ book.price }}</li>
{% endfor %} </ul> <ul class="pagination">
{% if page.has_previous %}
<li><a href="/index/?page={{ page.previous_page_number }}" aria-label="Previous">上一页</a></li>
{% else %}
<li class="disabled"><a href="" aria-label="Previous">上一页</a></li>
{% endif %} {% for pageNum in paginator.page_range %}
{% if num == pageNum %}
<li class="active"><a href="/index/?page={{ pageNum }}">{{ pageNum }}</a></li>
{% else %}
<li><a href="/index/?page={{ pageNum }}">{{ pageNum }}</a></li>
{% endif %}
{% endfor %} {% if page.has_next %}
<li><a href="/index/?page={{ page.next_page_number }}" aria-label="Next">下一页</a></li>
{% else %}
<li class="disabled"><a href="" aria-label="Next">下一页</a></li>
{% endif %}
</ul> </body>
</html>

django之补充的更多相关文章

  1. Django组件补充(缓存,信号,序列化)

    Django组件补充(缓存,信号,序列化) Django的缓存机制 1.1 缓存介绍 1.缓存的简介 在动态网站中,用户所有的请求,服务器都会去数据库中进行相应的增,删,查,改,渲染模板,执行业务逻辑 ...

  2. Python学习---django知识补充之CBV

    Django知识补充之CBV Django: url    -->  def函数      FBV[function based view]  用函数和URL进行匹配 url    --> ...

  3. Django 知识点补充

    Django 知识点补充 1 Django如何在Model保存前做一定的固定操作,比如写一条日志 (1)利用Django的Model的Signal Dispatcher, 通过django.db.mo ...

  4. django进阶补充

    前言: 这篇博客对上篇博客django进阶作下补充. 一.效果图 前端界面较简单(丑),有两个功能: 从数据库中取出书名 eg: 新书A 在form表单输入书名,选择出版社,选择作者(多选),输入完毕 ...

  5. Python之Django rest_Framework补充

    一.什么是RESTful REST与技术无关,代表的是一种软件架构风格,REST是Representational State Transfer的简称,中文翻译为"表征状态转移" ...

  6. Django知识补充

    目录 一.文件上传 二.Models补充 三.Django总结 一.文件上传 1.通过form表单或者通过From类上传 views.py from django.shortcuts import r ...

  7. Python菜鸟之路:Django 路由补充1:FBV和CBV - 补充2:url默认参数

    一.FBV和CBV 在Python菜鸟之路:Django 路由.模板.Model(ORM)一节中,已经介绍了几种路由的写法及对应关系,那种写法可以称之为FBV: function base view ...

  8. Python Django框架 补充

    Django REST framework ORM框架整理 Django框架 app间互借models字段的操作 ORM数据库操作补充:models中的一对一操作.过滤.事务 Django model ...

  9. Django Web补充

    一.今日内容 一.Django ORM连表操作 Q,F 二.Form表单验证 面向对象 正则 三.Session框架 面向对象 cookie toanado扩展 二.Django ORM一对多数据创建 ...

  10. 【django基础补充之URL,视图,模版】

    一.url路由配置 URL配置(URLconf)就像Django 所支撑网站的目录.它的本质是URL与要为该URL调用的视图函数之间的映射表:你就是以这种方式告诉Django,对于这个URL调用这段代 ...

随机推荐

  1. Codeforces Beta Round #72 (Div. 2 Only)

    Codeforces Beta Round #72 (Div. 2 Only) http://codeforces.com/contest/84 A #include<bits/stdc++.h ...

  2. linux同步机制2

    一.并发控制(1)自旋锁得不到资源,会原地打转,直到获得资源为止定义自旋锁 spinlock_t spin;初始化自旋锁 spin_lock_init(lock);获得自旋锁spin_lock(loc ...

  3. 微信小程序开发小技巧——单击事件传参、动态修改样式、轮播样式修改等

    一. 脚本部分: 1. 表达式无效的处理: 如果你发现自己编写的表达式无效或者数据不展示,那么请先检查你的表达式是否有添加{{}},小程序中全部都要添加的,只要是在模板中调用js中的数据 2. 获取元 ...

  4. vue 父子组件相互传参

    转自https://blog.csdn.net/u011175079/article/details/79161029 子组件: <template> <div> <di ...

  5. #define宏重定义

    #define A 1 在同一个工程的另外一个文件里又定义了#define A 2 并不会报错(2010vs) 亲测可用 但是最后该宏变量A的值 ,应该是预处理-----顺序处理------最后一个运 ...

  6. rviz2

    VINS-Mono ####Panels: 面板: - Class: rviz/Displays 显示1 Help Height: Name: Displays Property Tree Widge ...

  7. 函数的有用信息,装饰器 day12

    一 函数的有用信息 本函数的功能:绘图功能,实时接收数据并绘图.:return: 绘图需要的数据,返回给前端某标签 def f1(): ''' 本函数的功能:绘图功能,实时接收数据并绘图. :retu ...

  8. .Net连接字符串设置连接池大小显著提高数据库速度

    在访问mysql数据库时,如果在连接字符串中设置使用连接池,同时设置连接池大小,经测试,可以显著提高访问数据库时的速度. 连接字符串: connectionStrings>    <add ...

  9. Python使用filetype精确判断文件类型 (文件类型获取)

    filetype.py Small and dependency free Python package to infer file type and MIME type checking the m ...

  10. 史上最全的MSSQL复习笔记

    1.什么是SQL语句 SQL语言,结构化的查询语言(Structured Query Language),是关系数据库管理系统的标准语言.它是一种解释语言,写一句执行一句,不需要整体编译执行. 语法特 ...