最近从家里回来之后一直在想着减肥的事情,一个月都没更新博客了,今天下午没睡午觉就想着把mybatis的分页插件了解一下,由于上个月重新恢复了系统,之前创建的项目都没了,又重新创建了一个项目。

一、创建maven项目

主要创建了User类、UserMapper.xml、database.properties、mybatis-config.xml。

UserMapper.xml

  1. <?xml version="1.0" encoding="UTF-8" ?>
  2. <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
  3. <!-- 为这个mapper指定一个唯一的namespace,namespace的值习惯上设置成包名+sql映射文件名,这样就能够保证namespace的值是唯一的
  4. 例如namespace="Cuiyw.MyBatis.DBMapping.UserMapper"就是Cuiyw.MyBatis.DBMapping(包名)+UserMapper(UserMapper.xml文件去除后缀)
  5. -->
  6. <mapper namespace="Cuiyw.MyBatis.DBMapping.UserMapper">
  7. <!-- 在select标签中编写查询的SQL语句, 设置select标签的id属性为getUser,id属性值必须是唯一的,不能够重复
  8. 使用parameterType属性指明查询时使用的参数类型,resultType属性指明查询返回的结果集类型
  9. resultType="Cuiyw.MyBatis.Model.User"就表示将查询结果封装成一个User类的对象返回
  10. User类就是user表所对应的实体类
  11. -->
  12. <!--
  13. 根据id查询得到一个user对象
  14. -->
  15. <select id="getUser" parameterType="int"
  16. resultType="Cuiyw.MyBatis.Model.User">
  17. select * from user where id=#{id}
  18. </select>
  19. <select id="getUserList" resultType="Cuiyw.MyBatis.Model.User">
  20. select * from user
  21. </select>
  22. <insert id="addUser" parameterType="Cuiyw.MyBatis.Model.User">
  23. <selectKey resultType="java.lang.Integer" order="AFTER" keyProperty="id">
  24. SELECT LAST_INSERT_ID()
  25. </selectKey>
  26. insert into user(name,age) values (#{name},#{age})
  27. </insert>
  28. <delete id="deleteUserById" parameterType="int">
  29. delete from user where id=#{id}
  30. </delete>
  31. <update id="updateUser" parameterType="Cuiyw.MyBatis.Model.User">
  32. update user set name=#{name},age=#{age} where id=#{id}
  33. </update>
  34. </mapper>

User类

  1. package Cuiyw.MyBatis.Model;
  2.  
  3. public class User {
  4. @Override
  5. public String toString() {
  6. // TODO Auto-generated method stub
  7. return "User [id=" + Id + ", name=" + Name + ", age=" + Age + "]";
  8.  
  9. }
  10. public int getId() {
  11. return Id;
  12. }
  13. public void setId(int id) {
  14. Id = id;
  15. }
  16. public String getName() {
  17. return Name;
  18. }
  19. public void setName(String name) {
  20. Name = name;
  21. }
  22. public int getAge() {
  23. return Age;
  24. }
  25. public void setAge(int age) {
  26. Age = age;
  27. }
  28. private int Id;
  29. private String Name;
  30. private int Age;
  31. }

database.properties

  1. driver=com.mysql.jdbc.Driver
  2. url=jdbc:mysql://localhost:3306/mybatis

mybatis-config.xml

  1. <?xml version="1.0" encoding="UTF-8" ?>
  2. <!DOCTYPE configuration
  3. PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
  4. "http://mybatis.org/dtd/mybatis-3-config.dtd">
  5. <configuration>
  6. <properties resource="database.properties">
  7. <property name="username" value="root"/>
  8. <property name="password" value="123456"/>
  9. </properties>
  10. <typeAliases>
  11. <typeAlias type="Cuiyw.MyBatis.Model.User" alias="User"/>
  12. </typeAliases>
  13. <plugins>
  14. <!-- com.github.pagehelper为PageHelper类所在包名 -->
  15. <plugin interceptor="com.github.pagehelper.PageHelper">
  16. <!-- 方言 -->
  17. <property name="dialect" value="mysql"/>
  18. <!-- 该参数默认为false -->
  19. <!-- 设置为true时,使用RowBounds分页会进行count查询 -->
  20. <property name="rowBoundsWithCount" value="true"/>
  21. </plugin>
  22. </plugins>
  23. <environments default="development">
  24. <environment id="development">
  25. <transactionManager type="JDBC" />
  26. <!-- 配置数据库连接信息 -->
  27. <dataSource type="POOLED">
  28. <property name="driver" value="${driver}" />
  29. <property name="url" value="${url}" />
  30. <property name="username" value="${username}" />
  31. <property name="password" value="${password}" />
  32. </dataSource>
  33. </environment>
  34. </environments>
  35.  
  36. <!-- 程序中所用到sql映射文件都在这里列出,这些映射sql都被Mybatis管理 -->
  37. <mappers>
  38. <mapper resource="Cuiyw/MyBatis/DBMapping/UserMapper.xml" />
  39. </mappers>
  40.  
  41. </configuration>

二、pagehelper插件的配置

pom.xml配置

除了上面mybatis-config.xml中配置的plugin插件com.github.pagehelper.PageHelper.这里还主要使用了org.mybatis、mysql、com.github.pagehelper、com.github.jsqlparser,分页插件的是后面两个。

  1. <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  2. xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  3. <modelVersion>4.0.0</modelVersion>
  4.  
  5. <groupId>Cuiyw</groupId>
  6. <artifactId>MyBatisDemo</artifactId>
  7. <version>0.0.1-SNAPSHOT</version>
  8. <packaging>jar</packaging>
  9.  
  10. <name>MyBatisDemo</name>
  11. <url>http://maven.apache.org</url>
  12.  
  13. <properties>
  14. <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  15. </properties>
  16. <dependencies>
  17. <!-- https://mvnrepository.com/artifact/org.mybatis/mybatis -->
  18. <dependency>
  19. <groupId>org.mybatis</groupId>
  20. <artifactId>mybatis</artifactId>
  21. <version>3.2.1</version>
  22. </dependency>
  23. <!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java -->
  24. <dependency>
  25. <groupId>mysql</groupId>
  26. <artifactId>mysql-connector-java</artifactId>
  27. <version>5.1.6</version>
  28. </dependency>
  29. <dependency>
  30. <groupId>com.github.pagehelper</groupId>
  31. <artifactId>pagehelper</artifactId>
  32. <version>3.4.2</version>
  33. </dependency>
  34. <dependency>
  35. <groupId>com.github.jsqlparser</groupId>
  36. <artifactId>jsqlparser</artifactId>
  37. <version>0.9.1</version>
  38. </dependency>
  39. <dependency>
  40. <groupId>junit</groupId>
  41. <artifactId>junit</artifactId>
  42. <version>3.8.1</version>
  43. <scope>test</scope>
  44. </dependency>
  45. </dependencies>
  46. </project>

三、数据库配置

这里我事先在user表准备了一个几条数据。

四、插件的使用

PageHelper.startPage(1, 5, true)用来设置分页,PageInfo用来显示分页信息。

  1. package Cuiyw.MyBatisDemo;
  2. import java.io.IOException;
  3. import java.io.Reader;
  4. import java.util.List;
  5. import org.apache.ibatis.io.Resources;
  6. import org.apache.ibatis.session.SqlSession;
  7. import org.apache.ibatis.session.SqlSessionFactory;
  8. import org.apache.ibatis.session.SqlSessionFactoryBuilder;
  9.  
  10. import com.github.pagehelper.PageHelper;
  11. import com.github.pagehelper.PageInfo;
  12.  
  13. import Cuiyw.MyBatis.Model.User;
  14.  
  15. public class App
  16. {
  17. public static void main( String[] args ) throws IOException
  18. {
  19. //mybatis的配置文件
  20. String resource = "mybatis-config.xml";
  21. //使用MyBatis提供的Resources类加载mybatis的配置文件(它也加载关联的映射文件)
  22. Reader reader = Resources.getResourceAsReader(resource);
  23. //构建sqlSession的工厂
  24. SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder().build(reader);
  25. //创建能执行映射文件中sql的sqlSession
  26. SqlSession session = sessionFactory.openSession();
  27.  
  28. // String statement="Cuiyw.MyBatis.DBMapping.UserMapper.addUser";
  29. // User user=new User();
  30. // user.setName("Cuiyw");
  31. // user.setAge(27);
  32. // int result=session.insert(statement, user);
  33. // session.commit();
  34. // session.close();
  35. // System.out.println(user.getId());
  36. System.out.println("------所有记录----------");
  37. String statement="Cuiyw.MyBatis.DBMapping.UserMapper.getUserList";
  38. List<User>users=session.selectList(statement);
  39. for (User u: users) {
  40. System.out.println(u.toString());
  41. }
  42. System.out.println("------分页----------");
  43. PageHelper.startPage(1, 5, true);
  44. statement="Cuiyw.MyBatis.DBMapping.UserMapper.getUserList";
  45. users=session.selectList(statement);
  46. for (User u: users) {
  47. System.out.println(u.toString());
  48. }
  49.  
  50. PageInfo<User> pageInfo = new PageInfo<User>(users);
  51. System.out.println("数据总数:" + pageInfo.getTotal());
  52. System.out.println("数据总页数:" + pageInfo.getPages());
  53. System.out.println("最后一页:" + pageInfo.getLastPage());
  54.  
  55. for (User u: pageInfo.getList()) {
  56. System.out.println(u.toString());
  57. }
  58. }
  59. }

Mybatis之分页插件pagehelper的简单使用的更多相关文章

  1. Mybatis的分页插件PageHelper

    Mybatis的分页插件PageHelper 项目地址:http://git.oschina.net/free/Mybatis_PageHelper  文档地址:http://git.oschina. ...

  2. SpringBoot集成MyBatis的分页插件 PageHelper

    首先说说MyBatis框架的PageHelper插件吧,它是一个非常好用的分页插件,通常我们的项目中如果集成了MyBatis的话,几乎都会用到它,因为分页的业务逻辑说复杂也不复杂,但是有插件我们何乐而 ...

  3. Spring Boot系列教程八: Mybatis使用分页插件PageHelper

    一.前言 上篇博客中介绍了spring boot集成mybatis的方法,基于上篇文章这里主要介绍如何使用分页插件PageHelper.在MyBatis中提供了拦截器接口,我们可以使用PageHelp ...

  4. Spring Boot系列教程十一: Mybatis使用分页插件PageHelper

    一.前言 上篇博客中介绍了spring boot集成mybatis的方法,基于上篇文章这里主要介绍如何使用分页插件PageHelper.在MyBatis中提供了拦截器接口,我们可以使用PageHelp ...

  5. mybatis 分页插件PageHelper的简单使用

    首先在pom.xml配置文件中增加相关的插件. 插件地址:https://github.com/pagehelper/Mybatis-PageHelper <dependency> < ...

  6. 理解 Mybatis的分页插件 PageHelper

    Mybatis + SpringMVC + Maven实现分页查询 (推荐采用的插件是PageHelper) 先看一下之前的这篇博客,这里推荐了 Mybatis 的分页方法. 按照上面的方法设置后,确 ...

  7. Mybatis 的分页插件 PageHelper

    我用的版本是PageHelper-4.1.1.Mybatis-3.3.0 PageHelper 依赖于 jsqlparser-0.9.4.jar   使用方法: 1.根据Mybatis的版本下载对应版 ...

  8. Mybatis的分页插件PageHelper分页失效的原因

    引用博客:个人博客地址:https://alexaccele.github.io/ PageHelper是Mybatis的一个很好的分页插件,但要使用它的分页功能需要注意一下几点 1.导入相关包,例如 ...

  9. 学习Spring Boot:(八)Mybatis使用分页插件PageHelper

    首先Mybqtis可以通过SQL 的方式实现分页很简单,只要在查询SQL 后面加上limit #{currIndex} , #{pageSize}就可以了. 本文主要介绍使用拦截器的方式实现分页. 实 ...

随机推荐

  1. 使用itext生成pdf的,各种布局

    代码如下,jar包为itext.jar,itextAsia.jar,最好都是最新的 :2张图片也在最后贴出,把图片放到D盘可以直接生成制定格式的pdf. 最后生成的pdf如下: 代码如下: packa ...

  2. tabel表格的dom操作

    对table表格的操作比较麻烦,一直字符串的连接会比较麻烦 var nod = cwgk_msg_list.insertRow();//这个是上边获取过的dom元素,一般是tbody的元素,对元素进行 ...

  3. Zip包解压工具类

    最近在做项目的自动检测离线升级,使用到了解压zip包的操作,本着拿来主义精神,搞了个工具类(同事那边拿的),用着还不错. package com.winning.polaris.admin.utils ...

  4. java实现随机产生6位数的方法总结

    package com.yin.test; import java.util.Random; import org.junit.Test; /** * @author v_yinyl * @date ...

  5. Vuejs——(12)组件——动态组件

    版权声明:出处http://blog.csdn.net/qq20004604   目录(?)[+]   本篇资料来于官方文档: http://cn.vuejs.org/guide/components ...

  6. Centos7中docker开启远程访问

    在作为docker远程服务的centos7机器中配置: 1.在/usr/lib/systemd/system/docker.service,配置远程访问.主要是在[Service]这个部分,加上下面两 ...

  7. 【leetcode】 算法题3 无重复字符的最长子串

      问题      给定一个字符串,找出不含有重复字符的最长子串的长度. 示例: 给定 "abcabcbb" ,没有重复字符的最长子串是 "abc" ,那么长度 ...

  8. Varnish实现Web站点加速

    Varnish 是一款高性能的开源HTTP加速器,挪威最大的在线报纸 Verdens Gang使用3台Varnish代替了原来的12台Squid,性能比以前更好. Varnish 的作者Poul-He ...

  9. 牛客JS编程大题(二)

    11.统计数组 arr 中值等于 item 的元素出现的次数 function count(arr, item) { var num = 0; for(var i = 0;i < arr.len ...

  10. 【练习】Java中的读文件,文件的创建,写文件

    前言 大家好,给大家带来Java中的读文件,文件的创建,写文件的概述,希望你们喜欢 读文件 public static void read(String path,String filename){ ...