Oracle之分页
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Oracle之分页相关的知识,希望对你有一定的参考价值。
参考技术A 在Oracle中有一个方法rownum用来查询第一行到第n行的内容,但没有一个合适的方法若查询第x行到第y行的内容,而在实际应用中却经常需要查询第x行到第y行的内容,这时我们就需要使用rownum和子表查询等内容来进行查询,因为这一块内容属于Oracle总的常用部分所以专门在此介绍。在Oralce中有一个伪列rownum,其在创建表的时候就存在了却不显示,若要使用这个列可以直接调用即可,也可以对这个列添加别名来调用。
rownum只能用于显示小于某行的数据即第一行开始到你要查询到的那一行为止的数据。
在Oracle把查询第几行到第几行的操作称为分页,其具体操作是通过子查询等操作完成。
select 列名 from (select 表名.*,rownum rn from 表名)表名 where rn操作;
思考如下:
1.选择所有内容
select * from emp;
2.显示rownum
select e.*,rownum rn from(select * from emp)e;
这一步可以精简为下面形式,但某些情况只能用上面那种
select emp.*,rownum rn from emp;
3.查询
select * from(select e.*,rownum rn from (select * from emp)e);
4.其他变化
在某些时候我们需要先对表的内容进行排序,随后查询第x行到第y行的内容,这个时候有一个需要注意的点是rownum是在表产生的时候产生的伪列,所以使用排序会连着rownum的值进行排序,从而达不到想要的效果。
为了解决上述这个问题,我们需要使用子表查询即先排好序,再在新表之中显示rownum来规避这个问题。
考虑到排序的问题,所以在上方第二步的时候使用第一种方法即select e.*,rownum rn from(select * from emp)e;,在内表select * from emp中进行排序可以完成在乱序中找到第x行到第y行的效果。
Django组件之分页器
Django组件之分页器
分页器的使用
book_list=Book.objects.all() paginator = Paginator(book_list, 10) print("count:",paginator.count) #数据总数 print("num_pages",paginator.num_pages) #总页数 print("page_range",paginator.page_range) #页码的列表 page1=paginator.page(1) #第1页的page对象 for i in page1: #遍历第1页的所有数据对象 print(i) print(page1.object_list) #第1页的所有数据 page2=paginator.page(2) print(page2.has_next()) #是否有下一页 print(page2.next_page_number()) #下一页的页码 print(page2.has_previous()) #是否有上一页 print(page2.previous_page_number()) #上一页的页码 # 抛错 #page=paginator.page(12) # error:EmptyPage #page=paginator.page("z") # error:PageNotAnInteger ‘‘‘
实现示例
views.py from django.shortcuts import render,HttpResponse # Create your views here. from app01.models import Book from django.core.paginator import Paginator,EmptyPage def index(request): """ 创建数据 book_list=[] for i in range(100): book_obj=Book(title=‘book_%s‘%i, price=i*i) book_list.append(book_obj) Book.objects.bulk_create(book_list) """ book_list = Book.objects.all() paginator = Paginator(book_list, 3) # 一页显示多少条数据 try: print(paginator.count) # 数据总数 print(paginator.num_pages) # 总页数 print(paginator.page_range) # 页数range current_page_num = int(request.GET.get(‘page‘)) # 获取当前的页数 current_page = paginator.page(current_page_num) # 得到当前页数的页数对象 # 对分页码进行分类讨论
# 处理页码头 和 页码尾部的问题
if current_page_num-5 <1 : page_range = range(1,12) elif current_page_num+6 > paginator.num_pages: page_range=range(paginator.num_pages-11,paginator.num_pages+1) else: page_range = range(current_page_num-5,current_page_num+6) # 获取第一页数据的两种方法 # print(current_page.object_list) # for i in current_page: # print(i) except EmptyPage: current_page = paginator.page(1) return render(request,‘index.html‘,locals())
index.html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@3.3.7/dist/css/bootstrap.min.css" integrity="sha384-BVYiiSIFeK1dGmJRAkycuHAHRg32OmUcww7on3RYdg4Va+PmSTsz/K68vbdEjh4u" crossorigin="anonymous"> </head> <body> {% for book in current_page %} <p>{{ book.title }}:{{ book.price }}</p> {% endfor %} <nav aria-label="Page navigation"> <ul class="pagination"> {% if current_page.has_previous %} <li> <a href="?page={{ current_page.previous_page_number }}" aria-label="Previous"> <span aria-hidden="true">上一页</span> </a> </li> {% else %} <li class="disabled"> <a href="" aria-label="Previous"> <span aria-hidden="true">上一页</span> </a> </li> {% endif %} {% for item in page_range %} {% if item == current_page_num%} <li class="active"><a href="?page={{ item }}">{{ item }}</a></li> {% else %} <li><a href="?page={{ item }}">{{item}}</a></li> {% endif %} {% endfor %} {% if current_page.has_next %} <li> <a href="?path={{ current_page.next_page_number }}" aria-label="Next"> <span aria-hidden="true">下一页</span> </a> </li> {% else %} <li class="disabled"> <a href="" aria-label="Next"> <span aria-hidden="true">下一页</span> </a> </li> {% endif %} </ul> </nav> </body> </html>
以上是关于Oracle之分页的主要内容,如果未能解决你的问题,请参考以下文章