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-09FP-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-06Java基于正則表達(dá)式實(shí)現(xiàn)xml文件的解析功能詳解
這篇文章主要介紹了Java基于正則表達(dá)式實(shí)現(xiàn)xml文件的解析功能,結(jié)合實(shí)例形式分析了java使用正則表達(dá)式針對(duì)xml文件節(jié)點(diǎn)的相關(guān)操作技巧,需要的朋友可以參考下2017-08-08springboot增加注解緩存@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