mybatis分頁插件pageHelper詳解及簡單實例
工作的框架spring springmvc mybatis3
首先使用分頁插件必須先引入maven依賴,在pom.xml中添加如下
1
2
3
4
5
6
|
<!-- 分頁助手 --> < dependency > < groupId >com.github.pagehelper</ groupId > < artifactId >pagehelper</ artifactId > < version >3.7.5</ version > </ dependency > |
其次需要在配置文件中添加配置,有兩種方式
1,新建mybatis-config.xml內(nèi)容如下
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
<?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> <!-- 分頁助手 --> <plugins> <!-- com.github.pagehelper為PageHelper類所在包名 --> <plugin interceptor= "com.github.pagehelper.PageHelper" > <!-- 數(shù)據(jù)庫方言 --> <property name= "dialect" value= "MySQL" /> <!-- 設(shè)置為 true 時,使用RowBounds分頁會進行count查詢 會去查詢出總數(shù) --> <property name= "rowBoundsWithCount" value= "true" /> </plugin> </plugins> </configuration> |
在spring-mybatis.xml中添加一個bean屬性
1
2
|
<bean id= "sqlSessionFactory" class = "org.mybatis.spring.SqlSessionFactoryBean" > <property name= "dataSource" ref= "dataSource" /> |
加載全局的配置文件
1
|
<property name= "configLocation" value= "classpath:mybatis-config.xml" ></property> |
配置mapper的掃描,找到所有的mapper.xml映射文件。
1
|
<property name= "mapperLocations" value= "classpath:com/lyitong/mapping/*.xml" ></property> |
備注:如果你的mybatis-config.xml配置文件開啟了如下別名配置:
1
2
3
4
|
<typeAliases> <!-- javabean 的首字母小寫的非限定類名來作為它的別名(其實別名是不去分大小寫的)。也可在javabean 加上注解 @Alias 來自定義別名, 例如: @Alias (student) --> < package name= "com.lyt.usermanage.mapper" /> </typeAliases> |
那么你的spring和mybatis整合文件就得加上相應(yīng)的屬性,否則會造成mybatis配置文件加載不成功報異常,如下:
1
2
3
4
5
6
7
8
9
|
<bean id= "sqlSessionFactory" class = "org.mybatis.spring.SqlSessionFactoryBean" > <property name= "dataSource" ref= "dataSource" /> <!-- 加載全局的配置文件 --> <property name= "configLocation" value= "classpath:mybatis/mybatis-config.xml" ></property> <!-- 配置mapper的掃描,找到所有的mapper.xml映射文件。 --> <property name= "mapperLocations" value= "classpath:com/lyt/usermanage/mapper/*.xml" ></property> <!-- 配置類型別名 --> <property name= "typeAliasesPackage" value= "classpath:com/lyt/usermanage/pojo/*" ></property> </bean> |
相比于上面的配置我們這里多了一步
1
|
<property name= "typeAliasesPackage" value= "classpath:com/lyt/usermanage/pojo/*" ></property> |
配置的時候要注意mybatis配置文件和spring-mybatis整合文件的屬性要統(tǒng)一。
2.如上操作配置完成,下面第二種方法
直接在spring-mybatis.xml中配置如下屬性
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
<bean id= "sqlSessionFactory" class = "org.mybatis.spring.SqlSessionFactoryBean" > <property name= "dataSource" ref= "dataSource" /> <property name= "mapperLocations" value= "classpath:com/lyitong/mapping/*.xml" ></property> <!-- pageHelper 分頁插件 --> <property name= "plugins" > <array> <bean class = "com.github.pagehelper.PageHelper" > <property name= "properties" > <value> dialect=mysql rowBoundsWithCount= true </value> </property> </bean> </array> </property> </bean> |
配置文件加載好之后,就可以直接使用,具體使用代碼如下:
1
2
3
4
5
6
|
PageHelper.startPage(Integer.parseInt(currentPage), Integer.parseInt(pageSize)); List<LytBbsTz> publishTz = bbsTzDao.getPublishTz(userId); PageInfo<LytBbsTz> info = new PageInfo<LytBbsTz>(publishTz); map.put( "status" , 1 ); map.put( "tzList" , info.getList()); return map; |
前臺需要傳入的參數(shù)是當(dāng)前頁和頁面顯示數(shù)目,當(dāng)然頁面顯示數(shù)目也可以后臺規(guī)定,一般在接收參數(shù)時最好加上默認(rèn)配置如下:
1
|
@RequestParam (defaultValue= "1" ,value= "currentPage" )String currentPage, @RequestParam (defaultValue= "10" ,value= "pageSize" )String pageSize |
這是如果接收參數(shù)為空字符串時它自身默認(rèn)顯示的頁面和條數(shù),這個可以自己規(guī)定
以上就是pageHelper的簡單應(yīng)用
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
原文鏈接:http://blog.csdn.net/smile_miracle/article/details/53185655