Categories


Tags


三种数据库利用SQL语句进行高效果分页

在程序的开发过程中,处理分页是大家接触比较频繁的事件,因为现在软件基本上都是与数据库进行挂钓的。但效率又是我们所追求的,如果是像原来那样把所有满足条件的记录全部都选择出来,再去进行分页处理,那么就会多多的浪费掉许多的系统处理时间。为了能够把效率提高,所以现在我们就只选择我们需要的数据,减少数据库的处理时间,以下就是常用SQL分页处理:

1、SQL Server、Access数据库

这都微软的数据库,都是一家人,基本的操作都是差不多,常采用如下分页语句:

PAGESIZE:每页显示的记录数

CURRENTPAGE:当前页号

数据表的名字是:components

索引主键字是:id

select top PAGESIZE * from components where id not in

(select top (PAGESIZE*(CURRENTPAGE-1))

id from components order by id)order by id

如下列:

select top 10 * from components where id not in

(select top 10*10 id from components order by id)

order by id

从101条记录开始选择,只选择前面的10条记录

2、Oracle数据库

因为Oracle数据库没有Top关键字,所以这里就不能够像微软的数据据那样操作,这里有两种方法:

(1)、一种是利用相反的。

PAGESIZE:每页显示的记录数

CURRENTPAGE:当前页号

数据表的名字是:components

索引主键字是:id

select * from components where id not

in(select id from components where

rownum<=(PAGESIZE*(CURRENTPAGE-1)))

and rownum<=PAGESIZE order by id;

如下例:

select * from components where id not in

(select id from components where rownum<=100)

and rownum<=10 order by id;

从101到记录开始选择,选择前面10条。

(2)、使用minus,即中文的意思就是减去。

select * from components where rownum

<=(PAGESIZE*(CURRENTPAGE-1)) minus

select * from components where rownum

<=(PAGESIZE*(CURRENTPAGE-2));

如例:select * from components where

rownum<=10 minus select * from components

where rownum<=5;.

(3)、一种是利用Oracle的rownum,这个是Oracle查询自动返回的序号,一般不显示,但是可以通过select rownum from [表名]看到,注意,它是从1到当前的记录总数。

select * from (select rownum tid,components.

* from components where rownum<=100) where tid<=10;

3、MySQL数据库

Mysql可以使用 limit子句实现

select * from tablename limit start,number

返回从第 start+l条记录开始的number条记录。

来源:赛迪网

来源:月光博客


Public @ 2010-02-01 15:47:53

Windows Server 2008操作系统配置双网卡双IP

1.打开注册表,关闭 windows自带的“死网关监测”功能:在cmd中输入“regedit”注册表页面弹出后查找HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters\Interfaces下面的每一个子项分别代表一个网络适配器,每个子项会有一个叫 EnableDeadGWDetect 的值值名称: EnableD

Public @ 2019-03-30 15:47:07

使用SQL Server 2000索引视图提高性能

作者:Gail Erickson摘要:本文档介绍 SQL Server 2000 企业版的新功能 - 索引视图。讲解索引视图并讨论一些提高性能的具体方案。什么是索引视图?许多年来,Microsoft? SQL Server? 一直都提供创建虚拟表(称为视图)的功能。在过去,这些视图主要有两种用途:提供安全机制,将用户限制在一个或多个基表中的数据的某个子集。提供一种机制,允许开发人员定制用户如何才能

Public @ 2009-04-05 15:47:53

使用SQL Server 2000索引视图提高性能

SQL Server 2000索引视图是 SQL Server 引擎中的一种功能,可以帮助我们提高查询效率。它的作用是根据我们的特定的查询条件,把相关的数据保存到一个“虚拟表”中,这样就可以把查询操作分解成多个更简单的查询操作,从而帮助我们提高查询效率: 一、优点: 1. 快速检索,查询结果返回更快。 2. 更高的并发性,因为只有一个客户正在查询,所以可以支持更多的客户同时查询。 3

Public @ 2023-03-04 10:48:28

如何清除Sqlserver数据库日志

Sqlserver清理数据库方法①直接在我司网站【管理中心】-【业务管理】-【mssql数据库】-选择对应的ms-SqlServer数据库【管理】,点击【清理日志】即可清除日志。blob.pngSqlserver清理数据库方法②启用SqlServer客户端工具“Sql查询分析器”,选择"Sql Server身份认证",输入服务器地址、数据库登录名及密码,最后在命令框内输入:du

Public @ 2022-08-17 15:47:49

更多您感兴趣的搜索

0.466082s