使用Oracle实现的MyBatis分页查询效果
1、mybatis.xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"./mybatis-3-config.dtd">
<configuration>
<!-- properties配置文件中属性值,在整个配置文件中通过${}进行引用 -->
<properties>
<property name="driver" value="com.mysql.jdbc.Driver" />
</properties> <typeAliases>
<typeAlias type="com.wh.pojo.Emp" alias="Emp"/>
</typeAliases> <!-- 数据源环境信息配置 -->
<environments default="development2"> <environment id="development">
<transactionManager type="JDBC" />
<dataSource type="POOLED">
<!-- mysql数据源配置 -->
<property name="driver" value="${driver}" />
<property name="url" value="jdbc:mysql://localhost/ys" />
<property name="username" value="root" />
<property name="password" value="admin" />
</dataSource>
</environment> <environment id="development2">
<transactionManager type="JDBC" />
<dataSource type="POOLED">
<!-- oracle数据源配置 -->
<property name="driver" value="oracle.jdbc.driver.OracleDriver" />
<property name="url" value="jdbc:oracle:thin:@127.0.0.1:1521:orcl" />
<property name="username" value="scott" />
<property name="password" value="tiger" />
</dataSource>
</environment>
</environments> <mappers>
<mapper resource="com/wh/mapper/DeptMapper.xml" />
<mapper resource="com/wh/mapper/EmpMapper.xml" />
</mappers> </configuration>
2、EmpMapper.java
package com.wh.mapper; import java.util.List; import com.wh.common.PagerOracle;
import com.wh.pojo.Emp;
import com.wh.vo.VoOracle; public interface EmpMapper { public void insertDept(Emp emp); public List<Emp> selectAll(); public List<VoOracle> selectOracle(PagerOracle vo); }
3、EmpMapper.xml
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"./mybatis-3-mapper.dtd"> <!--namespace 绑定接口 -->
<mapper namespace="com.wh.mapper.EmpMapper"> <resultMap id="EmpResultMap" type="Emp">
<result property="pno" column="EMPNO" />
<result property="pname" column="ENAME" />
<result property="pjob" column="JOB" />
<result property="pmgr" column="MGR" />
<result property="phiredate" column="HIREDATE" />
<result property="psal" column="SAL" />
<result property="pcomm" column="COMM" />
<result property="pdeptno" column="DEPTNO" />
</resultMap> <!--查询所有 id 接口中的方法名 resultType 返回结果类型 resultType="com.wh.pojo.Dept"-->
<select id="selectAll" resultMap="EmpResultMap">
select * from EMP
</select> <!--oracle分页查询 -->
<select id="selectOracle" parameterType="com.wh.common.PagerOracle" resultType="com.wh.vo.VoOracle">
SELECT r.ename,r.dname,r.loc FROM (SELECT e.ename,d.dname,d.loc,ROWNUM s FROM dept d,emp e <![CDATA[ WHERE d.deptno=e.deptno AND ROWNUM<#{end} ) r where r.s>#{start} ]]> </select> </mapper>
4、EmpDaoImpl.java
package com.wh.mapperImpl; import java.util.List; import com.wh.common.PagerOracle;
import com.wh.mapper.EmpMapper;
import com.wh.pojo.Emp;
import com.wh.vo.VoOracle; public class EmpDaoImpl extends BaseDao implements EmpMapper { @Override
public List<Emp> selectAll() {
//获得连接
this.openSession();
//找到接口
EmpMapper mapper=(EmpMapper) ss.getMapper(EmpMapper.class);
return mapper.selectAll();
} @Override
public void insertDept(Emp emp) {
// TODO Auto-generated method stub } @Override
public List<VoOracle> selectOracle(PagerOracle vo) {
//获得连接
this.openSession();
//找到接口
EmpMapper mapper=(EmpMapper) ss.getMapper(EmpMapper.class);
return mapper.selectOracle(vo);
} }
5、PagerOracle.java
package com.wh.common;
public class PagerOracle {
private int recordCount;// 总记录数
private int pageSize = 5;// 每页个数 自定义
private int pageCount; // 总页数
private int pageNum;// 当前页数
private int start;// 起始记录数
private int end;
public PagerOracle(int recordCount, int pageNum) {
super();
this.recordCount = recordCount;
this.pageNum = pageNum;
// 总页数
if (recordCount % pageSize == 0) {
pageCount = recordCount / pageSize;
}
else {
pageCount = recordCount / pageSize + 1;
}
// 当前页码处理
if (pageNum < 1) {
pageNum = 1;
}
if (pageNum > pageCount) {
pageNum = pageCount;
}
// 起始位置 oracle从1开始
start = (pageNum-1) * pageSize+1;
end= start + pageSize - 1;
}
public int getRecordCount() {
return recordCount;
}
public void setRecordCount(int recordCount) {
this.recordCount = recordCount;
}
public int getPageSize() {
return pageSize;
}
public void setPageSize(int pageSize) {
this.pageSize = pageSize;
}
public int getPageCount() {
return pageCount;
}
public void setPageCount(int pageCount) {
this.pageCount = pageCount;
}
public int getPageNum() {
return pageNum;
}
public void setPageNum(int pageNum) {
this.pageNum = pageNum;
}
public int getStart() {
return start;
}
public void setStart(int start) {
this.start = start;
}
public int getEnd() {
return end;
}
public void setEnd(int end) {
this.end = end;
}
}
6、VoOracle.java
package com.wh.vo;
import com.wh.common.PagerOracle;
public class VoOracle {
private String ename;
private String dname;
private String Loc;
private PagerOracle pager;
public VoOracle() {
}
public VoOracle(PagerOracle pager) {
super();
this.pager = pager;
}
public String getEname() {
return ename;
}
public void setEname(String ename) {
this.ename = ename;
}
public String getDname() {
return dname;
}
public void setDname(String dname) {
this.dname = dname;
}
public String getLoc() {
return Loc;
}
public void setLoc(String loc) {
Loc = loc;
}
public PagerOracle getPager() {
return pager;
}
public void setPager(PagerOracle pager) {
this.pager = pager;
}
@Override
public String toString() {
return "VoOracle [ename=" + ename + ", dname=" + dname + ", Loc=" + Loc + ", pager=" + pager + "]";
}
}
TestEmp.java
package com.wh.junit;
/**
* mybatis编写顺序
* DeptMapper.java、DeptMapper.xml、DeptDaoImpl.java、TestMyBatis.java
*/
import java.io.IOException;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.List; import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.junit.Test; import com.wh.common.Pager;
import com.wh.common.PagerOracle;
import com.wh.mapperImpl.DeptDaoImpl;
import com.wh.mapperImpl.EmpDaoImpl;
import com.wh.pojo.Dept;
import com.wh.pojo.Emp;
import com.wh.vo.VO;
import com.wh.vo.VoOracle; public class TestEmp { //插入
@Test
public void testInsertDept() throws IOException{
// DeptDaoImpl dao=new DeptDaoImpl();
// dao.insertDept(new Dept(4,"技术","4楼"));
} //查询所有
@Test
public void testSelectAll() throws IOException{
EmpDaoImpl dao=new EmpDaoImpl();
List<Emp> list = dao.selectAll();
for(Emp p:list){
System.out.println(p);
}
} //Oracle分页查询
@Test
public void testSelectOracle() throws IOException{
EmpDaoImpl dao=new EmpDaoImpl();
//
List<VoOracle> list = dao.selectOracle(new PagerOracle(15,2));
for(VoOracle p:list){
System.out.println(p);
}
} }
使用Oracle实现的MyBatis分页查询效果的更多相关文章
- oracle count 百万级 分页查询记要总数、总条数优化
oracle count 百万级 分页查询记录总数.总条数优化 oracle count 百万级 查询记录总数.总条数优化 最近做一个项目时,做分页时,发现分页查询速度很慢,分页我做的是两次查询,一次 ...
- Oracle中的SQL分页查询原理和方法详解
Oracle中的SQL分页查询原理和方法详解 分析得不错! http://blog.csdn.net/anxpp/article/details/51534006
- Oracle和MySql的分页查询区别和PL/SQL的基本概念
Oracle和MySql的分页查询区别: Oracle的分析查询,之前Oracle的分页是使用伪列 ROWNUM 结合子查询实现,mysql的分页更简单,直接使用 LIMIT 关键字就可以实现 ...
- springmvc+spring+mybatis分页查询实例版本1,ver1.0
无聊做做看看,几乎没有怎么仔细做过这方面的,总是以为很简单,想想就会,实际做起来结合工作经验感觉还是挺有收获的,可以用在自己的项目上 第一版本思路:框架使用ssm,这个无所谓,采用分页语句查询指定页面 ...
- Oracle ROWNUM用法和分页查询总结(转)
[转载] Oracle的分页查询语句基本上可以按照本文给出的格式来进行套用. Oracle分页查询格式(一):http://yangtingkun.itpub.net/post/468/100278 ...
- Oracle ROWNUM用法和分页查询总结
**************************************************************************************************** ...
- mybatis分页查询需要注意的问题
一般对mybatis的分页查询的关键代码就两行: #currentPage代表当前页,pageSize代表每页的行数 PageHelper.startPage(currentPage, pageSiz ...
- [转]Oracle ROWNUM用法和分页查询总结
本文转自:http://blog.csdn.net/fw0124/article/details/42737671 ****************************************** ...
- MySQL、SqlServer、Oracle三大主流数据库分页查询
在这里主要讲解一下MySQL.SQLServer2000(及SQLServer2005)和ORCALE三种数据库实现分页查询的方法.可能会有人说这些网上都有,但我的主要目的是把这些知识通过我实际的应用 ...
随机推荐
- 2018/3/4 Activiti教程之对于流程的基本操作以及从发起到完成还有相关注意事项(与Springboot整合版)三
写教程实在太累了,,,还浪费时间,Activiti教程就写到这好了,不过最近在玩区块链,到时候写几个区块链方面的教程. 这是一些流程的查询与删除api,删除这块,默认是级联删除(加个false参数,就 ...
- 【NOIP2017练习】怎样打好隔膜(贪心,堆,带删除priority_queue)
题意:OI大师抖儿在夺得银牌之后,顺利保送pku.这一天,抖儿问长者:“我的手速虽然已经站在了人类的巅峰,但是打隔膜还是输.我换了很多队友,但是没有用.请问应该怎样打好隔膜?”长者回答:“你啊,Too ...
- 【Codevs1237&网络流24题餐巾计划】(费用流)
题意:一个餐厅在相继的 N 天里,每天需用的餐巾数不尽相同. 假设第 i 天需要 ri块餐巾(i=1,2,…,N).餐厅可以购买新的餐巾,每块餐巾的费用为 p 分: 或者把旧餐巾送到快洗部,洗一块需 ...
- Nginx配置文件nginx.conf 详解
#定义Nginx运行的用户和用户组 user www www; #nginx进程数,建议设置为等于CPU总核心数. worker_processes 8; #全局错误日志定义类型,[ debu ...
- Delphi DBGrid实现多选
DBGrid1.Options:= DBGrid1.Options+[dgMultiSelect]; //先设置DBGrid1的多选属性为True if DBGrid1.SelectedRows.C ...
- Ubuntu 16.04系统启动时卡在:(initramfs)
背景: 由于不正常的关机和重启,或者突然断电导致的关机,下次起来后不能进去系统,停留在(initramfs). 解决方法: 使用如下命令修复 fsck -y /dev/sda1 说明:其中sda1为系 ...
- Errors running builder 'JavaScript Validator' on
eclipse编译提示Errors running builder 'JavaScript Validator' on 解决方法见下图 去掉 'JavaScript Validator' 即可
- test markdown 写博客
欢迎使用 Cmd Markdown 编辑阅读器 我们理解您需要更便捷更高效的工具记录思想,整理笔记.知识,并将其中承载的价值传播给他人,Cmd Markdown 是我们给出的答案 -- 我们为记录思想 ...
- 【CV论文阅读】Deep Linear Discriminative Analysis, ICLR, 2016
DeepLDA 并不是把LDA模型整合到了Deep Network,而是利用LDA来指导模型的训练.从实验结果来看,使用DeepLDA模型最后投影的特征也是很discriminative 的,但是很遗 ...
- HDU 5265 pog loves szh II (二分查找)
[题目链接]click here~~ [题目大意]在给定 的数组里选两个数取模p的情况下和最大 [解题思路]: 思路见官方题解吧~~ 弱弱献上代码: Problem : 5265 ( pog love ...