mybaits 使用pagehelper实现分页

2024-05-29 08:38

本文主要是介绍mybaits 使用pagehelper实现分页,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一 pageHelper功能介绍

1.1 概述

1.mybaits可以使用第3方的插件来对功能进行扩展,分页助手pagehelper是将分页的负责操作进行封装,使用简单的方式即可获得分页的相关数据。

1.2  开发步骤

1.导入通用pageHelper的坐标

2.在mybaits的核心配置文件中配置pagehelper的插件

3.测试分页数据

二   操作案例

2.1 工程结构

2.2 配置pom依赖

    <dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.13</version><scope>test</scope></dependency><!--mywql dueong  --><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>5.1.32</version></dependency><!--mybaits --><dependency><groupId>org.mybatis</groupId><artifactId>mybatis</artifactId><version>3.4.5</version></dependency><!-- log4j--><dependency><groupId>log4j</groupId><artifactId>log4j</artifactId><version>1.2.17</version></dependency><!-- 分页插件--><dependency><groupId>com.github.pagehelper</groupId><artifactId>pagehelper</artifactId><version>3.7.5</version></dependency><dependency><groupId>com.github.jsqlparser</groupId><artifactId>jsqlparser</artifactId><version>0.9.1</version></dependency>

2.3 配置javabean

package com.ljf.mybaits.plugs.pagehelper.bean;/*** @ClassName: User* @Description: TODO* @Author: liujianfu* @Date: 2021/01/23 20:45:36 * @Version: V1.0**/
public class User
{private int id;private String userName;private String password;public int getId() {return id;}public void setId(int id) {this.id = id;}public String getUserName() {return userName;}public void setUserName(String userName) {this.userName = userName;}public String getPassword() {return password;}public void setPassword(String password) {this.password = password;}@Overridepublic String toString() {return "User{" +"id=" + id +", userName='" + userName + '\'' +", password='" + password + '\'' +'}';}
}

2.4 配置dao层

package com.ljf.mybaits.plugs.pagehelper.dao;import com.ljf.mybaits.plugs.pagehelper.bean.User;import java.io.IOException;
import java.util.List;public interface UserMapper {List<User> findAll() throws IOException;List<User> findByIds(List<Integer> dataList) throws IOException;
}

2.5 配置service层

1.service的接口层

package com.ljf.mybaits.plugs.pagehelper.service;import com.ljf.mybaits.plugs.pagehelper.bean.User;import java.io.IOException;
import java.util.List;public interface UserService {List<User> findAll() throws IOException;
}

2.service的实现层

package com.ljf.mybaits.plugs.pagehelper.service.impl;import com.github.pagehelper.PageHelper;
import com.github.pagehelper.PageInfo;
import com.ljf.mybaits.plugs.pagehelper.bean.User;
import com.ljf.mybaits.plugs.pagehelper.dao.UserMapper;
import com.ljf.mybaits.plugs.pagehelper.service.UserService;
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 java.io.IOException;
import java.io.InputStream;
import java.util.List;/*** @ClassName: UserServiceImpl* @Description: TODO* @Author: liujianfu* @Date: 2021/01/30 22:00:02 * @Version: V1.0**/
public class UserServiceImpl implements UserService {@Overridepublic List<User> findAll() throws IOException {//加载核心配置文件InputStream resourcesAsStream= Resources.getResourceAsStream("mybaitsConfig.xml");//获得sqlsession 工厂对象SqlSessionFactory sqlSessionFactory=new SqlSessionFactoryBuilder().build(resourcesAsStream);//获得sqlsession对象SqlSession sqlSession=sqlSessionFactory.openSession();//执行sqlUserMapper orgMapper=sqlSession.getMapper(UserMapper.class);//设置分页参数PageHelper.startPage(1,1);List<User> userList=orgMapper.findAll();//获得与分页相关参数PageInfo<User> pageInfo=new PageInfo<User>(userList);System.out.println("当前页:"+pageInfo.getPageNum());System.out.println("煤业显示条数:"+pageInfo.getPageSize());System.out.println("总条数:"+pageInfo.getTotal());System.out.println("上一页:"+pageInfo.getPrePage());System.out.println("下一页:"+pageInfo.getNextPage());System.out.println("是否第一个::"+pageInfo.isIsFirstPage());System.out.println("下一页:"+pageInfo.isIsLastPage());//mybaits 执行更新操作,提交事务sqlSession.commit();//关闭释放资源sqlSession.close();return userList;}
}

2.6 resource下的配置文件

1.userMapper.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
<!-- <mapper namespace="yonghuMapper">  -->
<mapper namespace="com.ljf.mybaits.plugs.pagehelper.dao.UserMapper"><!-- 查询, 在mybaitsconfig.xml文件中给起了别名 --><select id="findAll" resultType="yonghu">select id,user_name userName,password from tb_user</select></mapper>

2.mybaits-jdbc.properties 配置文件

jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/nongda
jdbc.username=root
jdbc.password=

3.mybaitsconfig.xml配置文件

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<properties resource="mybaits-jdbc.properties"></properties><!-- 起别名--><typeAliases><typeAlias type="com.ljf.mybaits.plugs.pagehelper.bean.User" alias="yonghu"></typeAlias></typeAliases><!-- 注册类型注册器<typeHandlers><typeHandler handler="com.mybaits.demo.handler.DataTypeTransfer"></typeHandler></typeHandlers>--><!--配置分页插件 --><plugins><plugin interceptor="com.github.pagehelper.PageHelper"><property name="dialect" value="mysql"/></plugin></plugins>
<!-- 数据源环境 --><environments default="development"><environment id="development"><transactionManager type="JDBC"></transactionManager><dataSource type="POOLED"><property name="driver" value="${jdbc.driver}"/><property name="url" value="${jdbc.url}"/><property name="username" value="${jdbc.username}"/><property name="password" value="${jdbc.password}"/></dataSource></environment></environments><!-- xxxmapper.xml都要在mybaits.config.xml文件中注册--><mappers><mapper resource="com/mybaits/mapper/UserMapper.xml"></mapper></mappers></configuration>

2.7 调用

package com.ljf.mybaits.plugs.pagehelper;import com.ljf.mybaits.plugs.pagehelper.bean.User;
import com.ljf.mybaits.plugs.pagehelper.service.UserService;
import com.ljf.mybaits.plugs.pagehelper.service.impl.UserServiceImpl;import java.io.IOException;
import java.util.List;/*** Hello world!**/
public class App 
{public static void main( String[] args ) throws IOException {UserService os=new UserServiceImpl();List<User> orgList=os.findAll();System.out.println("orglist:"+orgList);for(User u:orgList){System.out.println("u:"+u.getUserName());}System.out.println("....");System.out.println( "Hello World!" );}
}

结果:

这篇关于mybaits 使用pagehelper实现分页的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1013182

相关文章

Nginx 配置跨域的实现及常见问题解决

《Nginx配置跨域的实现及常见问题解决》本文主要介绍了Nginx配置跨域的实现及常见问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来... 目录1. 跨域1.1 同源策略1.2 跨域资源共享(CORS)2. Nginx 配置跨域的场景2.1

python使用库爬取m3u8文件的示例

《python使用库爬取m3u8文件的示例》本文主要介绍了python使用库爬取m3u8文件的示例,可以使用requests、m3u8、ffmpeg等库,实现获取、解析、下载视频片段并合并等步骤,具有... 目录一、准备工作二、获取m3u8文件内容三、解析m3u8文件四、下载视频片段五、合并视频片段六、错误

Python中提取文件名扩展名的多种方法实现

《Python中提取文件名扩展名的多种方法实现》在Python编程中,经常会遇到需要从文件名中提取扩展名的场景,Python提供了多种方法来实现这一功能,不同方法适用于不同的场景和需求,包括os.pa... 目录技术背景实现步骤方法一:使用os.path.splitext方法二:使用pathlib模块方法三

CSS实现元素撑满剩余空间的五种方法

《CSS实现元素撑满剩余空间的五种方法》在日常开发中,我们经常需要让某个元素占据容器的剩余空间,本文将介绍5种不同的方法来实现这个需求,并分析各种方法的优缺点,感兴趣的朋友一起看看吧... css实现元素撑满剩余空间的5种方法 在日常开发中,我们经常需要让某个元素占据容器的剩余空间。这是一个常见的布局需求

HTML5 getUserMedia API网页录音实现指南示例小结

《HTML5getUserMediaAPI网页录音实现指南示例小结》本教程将指导你如何利用这一API,结合WebAudioAPI,实现网页录音功能,从获取音频流到处理和保存录音,整个过程将逐步... 目录1. html5 getUserMedia API简介1.1 API概念与历史1.2 功能与优势1.3

gitlab安装及邮箱配置和常用使用方式

《gitlab安装及邮箱配置和常用使用方式》:本文主要介绍gitlab安装及邮箱配置和常用使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1.安装GitLab2.配置GitLab邮件服务3.GitLab的账号注册邮箱验证及其分组4.gitlab分支和标签的

Java实现删除文件中的指定内容

《Java实现删除文件中的指定内容》在日常开发中,经常需要对文本文件进行批量处理,其中,删除文件中指定内容是最常见的需求之一,下面我们就来看看如何使用java实现删除文件中的指定内容吧... 目录1. 项目背景详细介绍2. 项目需求详细介绍2.1 功能需求2.2 非功能需求3. 相关技术详细介绍3.1 Ja

SpringBoot3应用中集成和使用Spring Retry的实践记录

《SpringBoot3应用中集成和使用SpringRetry的实践记录》SpringRetry为SpringBoot3提供重试机制,支持注解和编程式两种方式,可配置重试策略与监听器,适用于临时性故... 目录1. 简介2. 环境准备3. 使用方式3.1 注解方式 基础使用自定义重试策略失败恢复机制注意事项

nginx启动命令和默认配置文件的使用

《nginx启动命令和默认配置文件的使用》:本文主要介绍nginx启动命令和默认配置文件的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录常见命令nginx.conf配置文件location匹配规则图片服务器总结常见命令# 默认配置文件启动./nginx

在Windows上使用qemu安装ubuntu24.04服务器的详细指南

《在Windows上使用qemu安装ubuntu24.04服务器的详细指南》本文介绍了在Windows上使用QEMU安装Ubuntu24.04的全流程:安装QEMU、准备ISO镜像、创建虚拟磁盘、配置... 目录1. 安装QEMU环境2. 准备Ubuntu 24.04镜像3. 启动QEMU安装Ubuntu4