java開發(fā)之Jdbc分頁源碼詳解
更新時(shí)間:2020年02月19日 15:58:51 作者:mianhuaman
這篇文章主要介紹了java開發(fā)之Jdb分頁源碼詳解,需要的朋友可以參考下
總之是用jdbc 的游標(biāo)移動(dòng)
package com.sp.person.sql.util;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.Map;
import java.util.TreeMap;
import javax.sql.DataSource;
/**
* 常常有同事在問JDBC 分頁查詢 這里給二個(gè)例子介紹一下
* JDBC 分頁查詢
* 分成二種方式希望對(duì)大家有所幫助
* 分另表示了absolute 與relative 的區(qū)別
* @see 這時(shí)用到一個(gè)數(shù)據(jù)源設(shè)計(jì)模式
* 數(shù)據(jù)源與數(shù)據(jù)庫連接沒有關(guān)系
* 例用接口回調(diào)的特性
* @author liuqing
* @version 1.0
*
*/
public class JdbcUtil {
/**
* 數(shù)據(jù)源
*/
private DataSource dataSource;
/**
* 不否啟用多數(shù)據(jù)源
*/
private boolean isMultipleDataSource;
/**
* 有時(shí)一個(gè)系統(tǒng)可能要使用多個(gè)數(shù)據(jù)源,存放多個(gè)數(shù)據(jù)源
*/
private Map<String,DataSource> dataSources = new TreeMap<String,DataSource>();
/**
* if true isMultipleDataSource is Key to DataSource
*/
private String dataSourceKey;
/**
* 默認(rèn)構(gòu)造器
*/
public JdbcUtil() {
}
/**
* 構(gòu)造器 Spring 的構(gòu)造器注入
* @param dataSource
*/
public JdbcUtil(DataSource dataSource) {
this.dataSource = dataSource;
}
/**
* JDBC 分頁查詢
* @param sql SQL 查詢語句
* @param firstSize 起始頁
* @param maxSize 返回?cái)?shù)據(jù)條數(shù)
* @return ResultSet
* @throws SQLException
*/
public ResultSet queryPageAbsolute(String sql,
int firstSize,int maxSize) throws SQLException {
PreparedStatement pre = this.getConn().prepareStatement(sql);
pre.setMaxRows(maxSize);
ResultSet rs = pre.executeQuery();
rs.absolute(firstSize * maxSize);
return rs;
}
/**
* JDBC 分頁查詢
* @param sql SQL 查詢語句
* @param firstSize 起始頁
* @param maxSize 返回?cái)?shù)據(jù)條數(shù)
* @return ResultSet 返回結(jié)果集
* @throws SQLException
*/
public ResultSet queryPageRelative(String sql,
int firstSize,int maxSize) throws SQLException {
PreparedStatement pre = getConn().prepareStatement(sql);
pre.setMaxRows(maxSize);
ResultSet rs = pre.executeQuery();
rs.relative(firstSize);
return rs;
}
/**
*
* @return Connection
* @throws SQLException
*/
private Connection getConn() throws SQLException {
//使用多數(shù)據(jù)源的情況
if (this.isMultipleDataSource) {
DataSource v_dataSource = this.queryDataSourceByKey();
if (v_dataSource != null) {
return v_dataSource.getConnection();
}
}
return this.dataSource.getConnection();
}
/**
* 獲得多數(shù)據(jù)源方法
* @return DataSource
*/
public DataSource queryDataSourceByKey() {
for (Map.Entry<String, DataSource> ds:this.dataSources.entrySet()) {
if (ds.getKey().equals(dataSourceKey)) {
return ds.getValue();
}
}
return null;
}
/**
* 獲得多數(shù)據(jù)源方法
* @return DataSource
*/
public DataSource queryDataSourceByKey(String useKey) {
for (Map.Entry<String, DataSource> ds:this.dataSources.entrySet()) {
if (ds.getKey().equals(useKey)) {
return ds.getValue();
}
}
return null;
}
/**
* 數(shù)據(jù)源
*/
public DataSource getDataSource() {
return dataSource;
}
/**
* 數(shù)據(jù)源 setter 注入
*/
public void setDataSource(DataSource dataSource) {
this.dataSource = dataSource;
}
/**
* @return the isMultipleDataSource
*/
public boolean isMultipleDataSource() {
return isMultipleDataSource;
}
/**
* @param isMultipleDataSource the isMultipleDataSource to set
*/
public void setMultipleDataSource(boolean isMultipleDataSource) {
this.isMultipleDataSource = isMultipleDataSource;
}
/**
* @return the dataSources
*/
public Map<String, DataSource> getDataSources() {
return dataSources;
}
/**
* @param dataSources the dataSources to set
*/
public void setDataSources(Map<String, DataSource> dataSources) {
this.dataSources = dataSources;
}
/**
* 返回當(dāng)前使用的數(shù)據(jù)源
* @return the dataSourceKey
*/
public String getDataSourceKey() {
return dataSourceKey;
}
/**
* 要使用的數(shù)據(jù)源為
* @param dataSourceKey the dataSourceKey to set
*/
public void setDataSourceKey(String dataSourceKey) {
this.dataSourceKey = dataSourceKey;
}
}
更多關(guān)于java開發(fā)之Jdb分頁源碼實(shí)例請(qǐng)查看下面的相關(guān)鏈接
您可能感興趣的文章:
- Java使用JDBC或MyBatis框架向Oracle中插入XMLType數(shù)據(jù)
- 在Java的Spring框架的程序中使用JDBC API操作數(shù)據(jù)庫
- java數(shù)據(jù)庫開發(fā)之JDBC的完整封裝兼容多種數(shù)據(jù)庫
- Java基礎(chǔ)開發(fā)之JDBC操作數(shù)據(jù)庫增刪改查,分頁查詢實(shí)例詳解
- 5分鐘快速學(xué)會(huì)spring boot整合JdbcTemplate的方法
- JDBC連接MySQL數(shù)據(jù)庫批量插入數(shù)據(jù)過程詳解
- 簡易JDBC框架實(shí)現(xiàn)過程詳解
相關(guān)文章
Java使用BigDecimal進(jìn)行高精度計(jì)算的示例代碼
本篇文章主要介紹了Java使用BigDecimal進(jìn)行高精度計(jì)算的示例代碼,具有一定的參考價(jià)值,有興趣的可以了解一下2017-09-09
FP-Growth算法的Java實(shí)現(xiàn)+具體實(shí)現(xiàn)思路+代碼
FP-Growth算法比Apriori算法快很多(但是卻比不上時(shí)間,how time slipped away)。在網(wǎng)上搜索后發(fā)現(xiàn)Java實(shí)現(xiàn)的FP-Growth算法很少,且大多數(shù)不太能理解):太菜。所以就自己實(shí)現(xiàn)了一下。這篇文章重點(diǎn)介紹一下我的Java實(shí)現(xiàn)2021-06-06
Java基于正則表達(dá)式實(shí)現(xiàn)xml文件的解析功能詳解
這篇文章主要介紹了Java基于正則表達(dá)式實(shí)現(xiàn)xml文件的解析功能,結(jié)合實(shí)例形式分析了java使用正則表達(dá)式針對(duì)xml文件節(jié)點(diǎn)的相關(guān)操作技巧,需要的朋友可以參考下2017-08-08
springboot增加注解緩存@Cacheable的實(shí)現(xiàn)
這篇文章主要介紹了springboot增加注解緩存@Cacheable的實(shí)現(xiàn),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-12-12
用IDEA創(chuàng)建SpringBoot項(xiàng)目的詳細(xì)步驟記錄
Idea有著非常簡便的Spring Boot新建過程,同時(shí)依靠pom自動(dòng)下載依賴,下面這篇文章主要給大家介紹了關(guān)于用IDEA創(chuàng)建SpringBoot項(xiàng)目的詳細(xì)步驟,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下2022-08-08
教你如何用Eclipse創(chuàng)建一個(gè)Maven項(xiàng)目
這篇文章主要介紹了教你如何用Eclipse創(chuàng)建一個(gè)Maven項(xiàng)目,文中有非常詳細(xì)的代碼示例,對(duì)正在入門Java的小伙伴們是非常有幫助的喲,需要的朋友可以參考下2021-05-05

