数据库分页
2015-12-14 09:25
471 查看
数据库分页(有时候忘了):
mysql:
public String getLimitString(String sql, Integer offset, Integer limit) {
sql = sql.trim();
sql+=" limit "+offset+","+limit;
return sql;
}
sqlserver:
public String getLimitString(String sql, Integer offset, Integer limit) {
sql = sql.trim();
int i=sql.indexOf("order");
String sqlfinal=sql.substring(0, i);
String order=sql.substring(i);
StringBuffer pageSql = new StringBuffer(sql.length() + 100);
// 其实这里还是有一点问题的,就是排序问题,指定死了,有解决的提供一下,等复习到Hibernate看看Hibernat内部是如何实现的。
pageSql.append("select * from(select a.*,row_number() over ("+order+") rownum from( ");
pageSql.append(sqlfinal);
pageSql.append(") a )b where rownum> " + offset + " and rownum <= " + (offset + limit));
return pageSql.toString();
}
oracle:
public String getLimitString(String sql, Integer offset, Integer limit) {
sql = sql.trim();
StringBuffer pagingSelect = new StringBuffer(sql.length() + 100);
pagingSelect.append("select * from ( select row_.*, rownum rownum_ from ( ");
pagingSelect.append(sql);
pagingSelect.append(" ) row_ ) where rownum_ > ").append(offset).append(" and rownum_ <= ").append(offset + limit);
return pagingSelect.toString();
}
mysql:
public String getLimitString(String sql, Integer offset, Integer limit) {
sql = sql.trim();
sql+=" limit "+offset+","+limit;
return sql;
}
sqlserver:
public String getLimitString(String sql, Integer offset, Integer limit) {
sql = sql.trim();
int i=sql.indexOf("order");
String sqlfinal=sql.substring(0, i);
String order=sql.substring(i);
StringBuffer pageSql = new StringBuffer(sql.length() + 100);
// 其实这里还是有一点问题的,就是排序问题,指定死了,有解决的提供一下,等复习到Hibernate看看Hibernat内部是如何实现的。
pageSql.append("select * from(select a.*,row_number() over ("+order+") rownum from( ");
pageSql.append(sqlfinal);
pageSql.append(") a )b where rownum> " + offset + " and rownum <= " + (offset + limit));
return pageSql.toString();
}
oracle:
public String getLimitString(String sql, Integer offset, Integer limit) {
sql = sql.trim();
StringBuffer pagingSelect = new StringBuffer(sql.length() + 100);
pagingSelect.append("select * from ( select row_.*, rownum rownum_ from ( ");
pagingSelect.append(sql);
pagingSelect.append(" ) row_ ) where rownum_ > ").append(offset).append(" and rownum_ <= ").append(offset + limit);
return pagingSelect.toString();
}
相关文章推荐
- SQL Server中角色与权限管理
- sql server 更改服务器帐户后会出现的问题
- Mongodb的CRUD
- python 连接 redis
- MySQL执行外部sql脚本文件的命令
- oracle 在一张日志表中,同一个ID 有多条记录,每个ID只获取最新时间的记录
- MongoDB(四)——管理架构
- Oracle数据库迁移-基础
- ORACLE 迁移
- mysql数据库配置安装
- Building Redis for use on Cygwin(转)
- Windows Cygwin Redis 安装(转)
- mysql
- mysql-5.7.9-winx64安装教程完整版,2015年12月win7
- 数据库下载
- mongodb的主从复制和副本集
- MySQL用作备份还原的导入和导出命令用法整理
- 分享Mysql命令大全
- redis-安装
- 捕捉MySQL慢查询