说说oracle分页的sql语句,分排序和不排序两种。

当结果集不需要进行排序时,每页显示条数为:rowPerPage,当前页数为:currentPage。

1、 相对来说,这种查询速度会快一些,因为当currentPage小时,嵌套语句查询的结果集小。但当currentPage 变大时,查询速度会慢慢变慢。当结果集很大时,查询第一页跟最后一页的速度会有明显变化。(倾向用这种!)

select * from(
select rownum r,  field1,field2 from table_name where rownum <= currentPage * rowPerPage

where r > (currentPage-1) * rowPerPage

2、相对来说,这种查询速度会慢一些,无论当currentPage大小,嵌套语句查询的结果集都是一样多的,都是整个结果集。但是,当结果集很大时,查询第一页跟最后一页的速度不会有明显变化。

select * from(
select rownum r,  field1,field2 from table_name 

where r  > (currentPage-1) * rowPerPage  and  r <= currentPage * rowPerPage

当需要进行排序时,以第一种方式进行示例如下:

select * from(
select rownum r, a.* from (
select  field1,field2 from table_name order by field1 
) a where rownum <= currentPage * rowPerPage
) where r > (currentPage-1) * rowPerPage

还有这个,也是很好用的:

select from 
  (select a.*,rownum row_num from 
          (select from tabelTest t order by t.id ) a
  ) b 
where b.row_num between (currentPage-1)*pagesize and currentPage*pagesize
后台,cs将json传入前台easy-ui的datagrid:
//
public string List(int page, int rows, string sort, string order, string DataBase)
{
string where = Common.HqlQeuryHelp.GetWhere(typeof(Model.TIPTOP.CPF_FILE), "CPF01,CPF02,CPF29,CPF31,CPF70,CPF35");
//string OracelStr = "select cpf01,cpf02,cpf29,cpf31,cpk02,cqi02,cqi06,cqi09,cqi06-cqi09 as diff,cpf70,cpf35,rownum as rowi from ";
// OracelStr += "tekvertps.cqi_file,tekvertps.cpf_file it,tekvertps.cpk_file where cpf31=cpk01 and cpf01=cqi01 and cpf35 is null and rownum<100"; string OracelStr = "select cpf01,cpf02,cpf29,cpf31,cpk02,cqi02,cqi06,cqi09,cqi06-cqi09 as diff,cpf70,cpf35,rownum as r from ";
OracelStr += "(select cpf01,cpf02,cpf29,cpf31,cpk02,cqi02,cqi06,cqi09,cqi06-cqi09 as diff,cpf70,cpf35,rownum row_num from ";
OracelStr += "tekvertps.cpf_file, tekvertps.cqi_file,tekvertps.cpk_file where cpf31=cpk01 and cpf01=cqi01 and cpf35 is null order by cpf01 ) it ";
OracelStr += "where it.row_num between " + (page-1)*rows +" and " + page*rows; if (!string.IsNullOrEmpty(where)) { OracelStr += " and " + where; }
OracleDataReader dr = OA.Common.OracleHelper.ExecuteReader(OA.Common.OracleHelper.ConnectionStringTipTopTPS, CommandType.Text, OracelStr, null);
var cpfbll = new BLL.TIPTOP.CPF_FILE(DataBase);
var count = cpfbll.GetTextCount(where); List<object> listView = new List<object>();
foreach (var i in dr)
{
listView.Add(new
{
CPF01 = dr["CPF01"].ToString(),
CPF02 = dr["CPF02"].ToString(),
CPF29 = dr["CPF29"].ToString(),
CPF31 = dr["CPF31"].ToString(),
CPK02 = dr["CPK02"].ToString(),
CQI02 = dr["CQI02"].ToString(),
CQI06 = dr["CQI06"].ToString(),
CQI09 = dr["CQI09"].ToString(),
DIFF = dr["DIFF"].ToString(),
CPF70 = Formate_Date((DateTime)dr["CPF70"]),
CPF35 = dr["CPF35"].ToString()
});
}
var ret = new
{
total = count,
rows = listView
};
return ToJsonString(ret);
}

前台(MVC easyui-datagrid):

 <div region="center" border="false">
<table class="easyui-datagrid" id="details" data-options="fit:true,singleSelect:true, fitColumns:true,pageSize:10,
pagination:true,rownumbers:true,border:true,url:serverUrl.list,view: detailview,detailFormatter:detailformatter,onExpandRow:rowExpand">
<thead>
<tr>
<th data-options="field:'CPF01',sortable:true,width:100">員工代號</th>
<th data-options="field:'CPF02',sortable:true,width:100">姓名</th>
<th data-options="field:'CPF29',sortable:true,width:100">部門別</th>
<th data-options="field:'CPF31',sortable:true,width:100">職稱代號</th>
<th data-options="field:'CPK02',sortable:true,width:100">職稱</th>
<th data-options="field:'CQI02',sortable:true,width:100">年度</th>
<th data-options="field:'CQI06',sortable:true,width:100">特休天數</th>
<th data-options="field:'CQI09',sortable:true,width:100">已休天數</th>
<th data-options="field:'DIFF',sortable:true,width:100">未休天數</th>
<th data-options="field:'CQH071S1',sortable:true,width:100">事假天數</th>
<th data-options="field:'CQH071S2',sortable:true,width:100">病假天數</th>
<th data-options="field:'CPF70',sortable:true,width:100">到職日期</th>
<th data-options="field:'CPF35',sortable:true,width:100">離職日期</th>
</tr>
</thead>
</table>
</div>

说说oracle分页的sql语句的更多相关文章

  1. oracle 分页的sql语句

    已知有两种方法效率上貌似第一种更优: 1. select * from( select t1.*, rownum n from (select * from cm_log order by oper_ ...

  2. Oracle分页查询sql语句

    1. select * from ( select  t.*, rownum RN from TABLE_NAME  t ) where RN > 0 and RN <= 15 2. se ...

  3. Oracle数据库 基础SQL语句练习

    一.说明 第一次使用Oracle,想做一些练习,熟悉一些oracle. 表:使用的是scott用户,默认的表 具体表讲解,可以参考该文档:https://www.cnblogs.com/xjcheng ...

  4. oracle中查看sql语句的执行计划

    1.在pl/sql中打开cmd命令容器 2.在cmd命令窗口中输入:explain plan for select * from t; 3.查看sql语句的执行计划:select * from tab ...

  5. Oracle 的分页查询 SQL 语句

    Oracle的分页查询语句基本上可以按照本文给出的格式来进行套用. 分页查询格式: SELECT * FROM (SELECT A.*, ROWNUM RN FROM (SELECT * FROM T ...

  6. ORACLE分页查询SQL语法——最高效的分页

    --1:无ORDER BY排序的写法.(效率最高)--(经过测试,此方法成本最低,只嵌套一层,速度最快!即使查询的数据量再大,也几乎不受影响,速度依然!) SELECT * FROM (SELECT  ...

  7. ORACLE分页查询SQL语法——高效的分页

    --1:无ORDER BY排序的写法.(效率最高)--(经过测试,此方法成本最低,只嵌套一层,速度最快!即使查询的数据量再大,也几乎不受影响,速度依然!) SELECT * FROM (SELECT  ...

  8. 160321、ORACLE分页查询SQL语法——最高效的分页

    --1:无ORDER BY排序的写法.(效率最高) --(经过测试,此方法成本最低,只嵌套一层,速度最快!即使查询的数据量再大,也几乎不受影响,速度依然!) SELECT *   FROM (SELE ...

  9. Oracle数据库的sql语句性能优化

    在应用系统开发初期,由于开发数据库数据比较少,对于查询sql语句,复杂试图的编写等体会不出sql语句各种写法的性能优劣,但是如果将应用系统提交实际应用后,随着数据库中数据的增加,系统的响应速度就成为目 ...

随机推荐

  1. php--validate错误信息提示样式

    //validate  错误信息提示样式  可以提示错误信息 可以使用jq 自带的属性改变错误的显示的位置,其中element是验证未通过的当前表单元素,error为错误后的提示信息 [注意]:放的位 ...

  2. IIS Express启动命令

    http://www.iis.net/learn/extensions/using-iis-express/running-iis-express-from-the-command-line C:\P ...

  3. Android生命周期详细说明

    提供两个关于Activity的生命周期模型图示帮助理解:                                           图1 图2 从图2所示的Activity生命周期不难看出, ...

  4. Magento去掉价格的小数点

    magento的默认情况,价格后面是有小数点的,我们来看下如何正确的来去掉小数点. 1.复制如下路径的文件 app/code/core/Mage/Directory/Model/Currency.ph ...

  5. 移动端公共css样式

    @media screen and ( min-width: 319px){html{ font-size: 100px;}}@media screen and ( min-width: 359px) ...

  6. 优化系统资源ulimit《高性能Linux服务器构建实战:运维监控、性能调优与集群应用》

    优化系统资源ulimit<高性能Linux服务器构建实战:运维监控.性能调优与集群应用> 假设有这样一种情况,一台Linux 主机上同时登录了10个用户,在没有限制系统资源的情况下,这10 ...

  7. Android Error:warning: Ignoring InnerClasses attribute for an anonymous inner class

    今天项目发布时遇到了这个问题,在低版本设备上面死活发布不上去,还有打包也打不成功,折腾了好长一段时间,网上大部分给出的 解决方案都是说 在工程的混淆配置文件 proguard-rules.pro 中加 ...

  8. ionic 上拉加载更多&瀑布流加载&滚动到底部加载更多 主意事项

    首先下拉刷新的代码是这样的,标红的地方为关键代码 <html> <head> <meta charset="utf-8"> <meta n ...

  9. 知识准备-JOIN/EXISTS

    10:40 2013-08-29 JOIN ON...AND A left join B on A.col1=B.col1 and A.col2=xx A left join B on A.col1= ...

  10. Sublime text 3 SVN插件及使用方法

    前提是你电脑里已装有SVN,这时只是设置快捷调用SVN. 1.通过快捷键 ctrl+` 或者 View > Show Console 菜单打开控制台 2.粘贴对应版本的代码后回车安装 适用于 S ...