Mybatis之分页插件pagehelper的简单使用
最近从家里回来之后一直在想着减肥的事情,一个月都没更新博客了,今天下午没睡午觉就想着把mybatis的分页插件了解一下,由于上个月重新恢复了系统,之前创建的项目都没了,又重新创建了一个项目。
一、创建maven项目
主要创建了User类、UserMapper.xml、database.properties、mybatis-config.xml。
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,namespace的值习惯上设置成包名+sql映射文件名,这样就能够保证namespace的值是唯一的
- 例如namespace="Cuiyw.MyBatis.DBMapping.UserMapper"就是Cuiyw.MyBatis.DBMapping(包名)+UserMapper(UserMapper.xml文件去除后缀)
- -->
- <mapper namespace="Cuiyw.MyBatis.DBMapping.UserMapper">
- <!-- 在select标签中编写查询的SQL语句, 设置select标签的id属性为getUser,id属性值必须是唯一的,不能够重复
- 使用parameterType属性指明查询时使用的参数类型,resultType属性指明查询返回的结果集类型
- resultType="Cuiyw.MyBatis.Model.User"就表示将查询结果封装成一个User类的对象返回
- User类就是user表所对应的实体类
- -->
- <!--
- 根据id查询得到一个user对象
- -->
- <select id="getUser" parameterType="int"
- resultType="Cuiyw.MyBatis.Model.User">
- select * from user where id=#{id}
- </select>
- <select id="getUserList" resultType="Cuiyw.MyBatis.Model.User">
- select * from user
- </select>
- <insert id="addUser" parameterType="Cuiyw.MyBatis.Model.User">
- <selectKey resultType="java.lang.Integer" order="AFTER" keyProperty="id">
- SELECT LAST_INSERT_ID()
- </selectKey>
- insert into user(name,age) values (#{name},#{age})
- </insert>
- <delete id="deleteUserById" parameterType="int">
- delete from user where id=#{id}
- </delete>
- <update id="updateUser" parameterType="Cuiyw.MyBatis.Model.User">
- update user set name=#{name},age=#{age} where id=#{id}
- </update>
- </mapper>
User类
- package Cuiyw.MyBatis.Model;
- public class User {
- @Override
- public String toString() {
- // TODO Auto-generated method stub
- return "User [id=" + Id + ", name=" + Name + ", age=" + Age + "]";
- }
- public int getId() {
- return Id;
- }
- public void setId(int id) {
- Id = id;
- }
- public String getName() {
- return Name;
- }
- public void setName(String name) {
- Name = name;
- }
- public int getAge() {
- return Age;
- }
- public void setAge(int age) {
- Age = age;
- }
- private int Id;
- private String Name;
- private int Age;
- }
database.properties
- driver=com.mysql.jdbc.Driver
- url=jdbc:mysql://localhost:3306/mybatis
mybatis-config.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="database.properties">
- <property name="username" value="root"/>
- <property name="password" value="123456"/>
- </properties>
- <typeAliases>
- <typeAlias type="Cuiyw.MyBatis.Model.User" alias="User"/>
- </typeAliases>
- <plugins>
- <!-- com.github.pagehelper为PageHelper类所在包名 -->
- <plugin interceptor="com.github.pagehelper.PageHelper">
- <!-- 方言 -->
- <property name="dialect" value="mysql"/>
- <!-- 该参数默认为false -->
- <!-- 设置为true时,使用RowBounds分页会进行count查询 -->
- <property name="rowBoundsWithCount" value="true"/>
- </plugin>
- </plugins>
- <environments default="development">
- <environment id="development">
- <transactionManager type="JDBC" />
- <!-- 配置数据库连接信息 -->
- <dataSource type="POOLED">
- <property name="driver" value="${driver}" />
- <property name="url" value="${url}" />
- <property name="username" value="${username}" />
- <property name="password" value="${password}" />
- </dataSource>
- </environment>
- </environments>
- <!-- 程序中所用到sql映射文件都在这里列出,这些映射sql都被Mybatis管理 -->
- <mappers>
- <mapper resource="Cuiyw/MyBatis/DBMapping/UserMapper.xml" />
- </mappers>
- </configuration>
二、pagehelper插件的配置
pom.xml配置
除了上面mybatis-config.xml中配置的plugin插件com.github.pagehelper.PageHelper.这里还主要使用了org.mybatis、mysql、com.github.pagehelper、com.github.jsqlparser,分页插件的是后面两个。
- <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
- <modelVersion>4.0.0</modelVersion>
- <groupId>Cuiyw</groupId>
- <artifactId>MyBatisDemo</artifactId>
- <version>0.0.1-SNAPSHOT</version>
- <packaging>jar</packaging>
- <name>MyBatisDemo</name>
- <url>http://maven.apache.org</url>
- <properties>
- <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
- </properties>
- <dependencies>
- <!-- https://mvnrepository.com/artifact/org.mybatis/mybatis -->
- <dependency>
- <groupId>org.mybatis</groupId>
- <artifactId>mybatis</artifactId>
- <version>3.2.1</version>
- </dependency>
- <!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java -->
- <dependency>
- <groupId>mysql</groupId>
- <artifactId>mysql-connector-java</artifactId>
- <version>5.1.6</version>
- </dependency>
- <dependency>
- <groupId>com.github.pagehelper</groupId>
- <artifactId>pagehelper</artifactId>
- <version>3.4.2</version>
- </dependency>
- <dependency>
- <groupId>com.github.jsqlparser</groupId>
- <artifactId>jsqlparser</artifactId>
- <version>0.9.1</version>
- </dependency>
- <dependency>
- <groupId>junit</groupId>
- <artifactId>junit</artifactId>
- <version>3.8.1</version>
- <scope>test</scope>
- </dependency>
- </dependencies>
- </project>
三、数据库配置
这里我事先在user表准备了一个几条数据。
四、插件的使用
PageHelper.startPage(1, 5, true)用来设置分页,PageInfo用来显示分页信息。
- package Cuiyw.MyBatisDemo;
- import java.io.IOException;
- import java.io.Reader;
- 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 com.github.pagehelper.PageHelper;
- import com.github.pagehelper.PageInfo;
- import Cuiyw.MyBatis.Model.User;
- public class App
- {
- public static void main( String[] args ) throws IOException
- {
- //mybatis的配置文件
- String resource = "mybatis-config.xml";
- //使用MyBatis提供的Resources类加载mybatis的配置文件(它也加载关联的映射文件)
- Reader reader = Resources.getResourceAsReader(resource);
- //构建sqlSession的工厂
- SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder().build(reader);
- //创建能执行映射文件中sql的sqlSession
- SqlSession session = sessionFactory.openSession();
- // String statement="Cuiyw.MyBatis.DBMapping.UserMapper.addUser";
- // User user=new User();
- // user.setName("Cuiyw");
- // user.setAge(27);
- // int result=session.insert(statement, user);
- // session.commit();
- // session.close();
- // System.out.println(user.getId());
- System.out.println("------所有记录----------");
- String statement="Cuiyw.MyBatis.DBMapping.UserMapper.getUserList";
- List<User>users=session.selectList(statement);
- for (User u: users) {
- System.out.println(u.toString());
- }
- System.out.println("------分页----------");
- PageHelper.startPage(1, 5, true);
- statement="Cuiyw.MyBatis.DBMapping.UserMapper.getUserList";
- users=session.selectList(statement);
- for (User u: users) {
- System.out.println(u.toString());
- }
- PageInfo<User> pageInfo = new PageInfo<User>(users);
- System.out.println("数据总数:" + pageInfo.getTotal());
- System.out.println("数据总页数:" + pageInfo.getPages());
- System.out.println("最后一页:" + pageInfo.getLastPage());
- for (User u: pageInfo.getList()) {
- System.out.println(u.toString());
- }
- }
- }
Mybatis之分页插件pagehelper的简单使用的更多相关文章
- Mybatis的分页插件PageHelper
Mybatis的分页插件PageHelper 项目地址:http://git.oschina.net/free/Mybatis_PageHelper 文档地址:http://git.oschina. ...
- SpringBoot集成MyBatis的分页插件 PageHelper
首先说说MyBatis框架的PageHelper插件吧,它是一个非常好用的分页插件,通常我们的项目中如果集成了MyBatis的话,几乎都会用到它,因为分页的业务逻辑说复杂也不复杂,但是有插件我们何乐而 ...
- Spring Boot系列教程八: Mybatis使用分页插件PageHelper
一.前言 上篇博客中介绍了spring boot集成mybatis的方法,基于上篇文章这里主要介绍如何使用分页插件PageHelper.在MyBatis中提供了拦截器接口,我们可以使用PageHelp ...
- Spring Boot系列教程十一: Mybatis使用分页插件PageHelper
一.前言 上篇博客中介绍了spring boot集成mybatis的方法,基于上篇文章这里主要介绍如何使用分页插件PageHelper.在MyBatis中提供了拦截器接口,我们可以使用PageHelp ...
- mybatis 分页插件PageHelper的简单使用
首先在pom.xml配置文件中增加相关的插件. 插件地址:https://github.com/pagehelper/Mybatis-PageHelper <dependency> < ...
- 理解 Mybatis的分页插件 PageHelper
Mybatis + SpringMVC + Maven实现分页查询 (推荐采用的插件是PageHelper) 先看一下之前的这篇博客,这里推荐了 Mybatis 的分页方法. 按照上面的方法设置后,确 ...
- Mybatis 的分页插件 PageHelper
我用的版本是PageHelper-4.1.1.Mybatis-3.3.0 PageHelper 依赖于 jsqlparser-0.9.4.jar 使用方法: 1.根据Mybatis的版本下载对应版 ...
- Mybatis的分页插件PageHelper分页失效的原因
引用博客:个人博客地址:https://alexaccele.github.io/ PageHelper是Mybatis的一个很好的分页插件,但要使用它的分页功能需要注意一下几点 1.导入相关包,例如 ...
- 学习Spring Boot:(八)Mybatis使用分页插件PageHelper
首先Mybqtis可以通过SQL 的方式实现分页很简单,只要在查询SQL 后面加上limit #{currIndex} , #{pageSize}就可以了. 本文主要介绍使用拦截器的方式实现分页. 实 ...
随机推荐
- 使用itext生成pdf的,各种布局
代码如下,jar包为itext.jar,itextAsia.jar,最好都是最新的 :2张图片也在最后贴出,把图片放到D盘可以直接生成制定格式的pdf. 最后生成的pdf如下: 代码如下: packa ...
- tabel表格的dom操作
对table表格的操作比较麻烦,一直字符串的连接会比较麻烦 var nod = cwgk_msg_list.insertRow();//这个是上边获取过的dom元素,一般是tbody的元素,对元素进行 ...
- Zip包解压工具类
最近在做项目的自动检测离线升级,使用到了解压zip包的操作,本着拿来主义精神,搞了个工具类(同事那边拿的),用着还不错. package com.winning.polaris.admin.utils ...
- java实现随机产生6位数的方法总结
package com.yin.test; import java.util.Random; import org.junit.Test; /** * @author v_yinyl * @date ...
- Vuejs——(12)组件——动态组件
版权声明:出处http://blog.csdn.net/qq20004604 目录(?)[+] 本篇资料来于官方文档: http://cn.vuejs.org/guide/components ...
- Centos7中docker开启远程访问
在作为docker远程服务的centos7机器中配置: 1.在/usr/lib/systemd/system/docker.service,配置远程访问.主要是在[Service]这个部分,加上下面两 ...
- 【leetcode】 算法题3 无重复字符的最长子串
问题 给定一个字符串,找出不含有重复字符的最长子串的长度. 示例: 给定 "abcabcbb" ,没有重复字符的最长子串是 "abc" ,那么长度 ...
- Varnish实现Web站点加速
Varnish 是一款高性能的开源HTTP加速器,挪威最大的在线报纸 Verdens Gang使用3台Varnish代替了原来的12台Squid,性能比以前更好. Varnish 的作者Poul-He ...
- 牛客JS编程大题(二)
11.统计数组 arr 中值等于 item 的元素出现的次数 function count(arr, item) { var num = 0; for(var i = 0;i < arr.len ...
- 【练习】Java中的读文件,文件的创建,写文件
前言 大家好,给大家带来Java中的读文件,文件的创建,写文件的概述,希望你们喜欢 读文件 public static void read(String path,String filename){ ...