利用pagehelper在ssm框架中完成分页查询

利用pagehelper在ssm框架中完成分页查询

一、pagehelper属性解释

//当前页
private int pageNum;
//每页的数量
private int pageSize;
//当前页的数量
private int size;
//排序
private String orderBy;

//当前页面第一个元素在数据库中的行号
private int startRow;
//当前页面最后一个元素在数据库中的行号
private int endRow;
//总记录数
private long total;
//总页数
private int pages;
//结果集
private List<T> list;

//第一页
private int firstPage;
//前一页
private int prePage;
//下一页
private int nextPage;
//最后一页
private int lastPage;

//是否为第一页
private boolean isFirstPage = false;
//是否为最后一页
private boolean isLastPage = false;
//是否有前一页
private boolean hasPreviousPage = false;
//是否有下一页
private boolean hasNextPage = false;
//导航页码数
private int navigatePages;
//所有导航页号
private int[] navigatepageNums;

二、配置分页插件

2.1 导入pagehelper依赖

在pom.xml文件中导入pagehelper依赖

<dependency>
    <groupId>com.github.pagehelper</groupId>
    <artifactId>pagehelper</artifactId>
    <version>5.1.11</version>
</dependency>

2.2 配置分页插件

在applicationContext.xml中,配置sqlSessionFactoryBean的标签中配置分页插件。

<!--配置pageHelper 分页插件-->
<property name="plugins">
    <set>
        <bean class="com.github.pagehelper.PageInterceptor">
            <property name="properties">
                <props>
                    <!--配置数据库-->
                    <prop key="helperDialect">mysql</prop>
                    <!--当pageNum<1时,默认查询第一页,当pageNum>totalPage时,默认查询最后一页-->
					<prop key="reasonable">true</prop>
                    <!-- 支持接口传参-->
                    <prop key="supportMethodsArguments">true</prop>
                </props>
            </property>
        </bean>
    </set>
</property>

三、编写查询方法

普通的查询sql即可,sql语句无需添加分页语句。

四、编写controller

@RequestMapping("list")
public String selectAllVideo
    
    /*@RequestParam:把请求中的指定名称的参数传递给控制器中的形参赋值。
    		value:请求参数中的名称
			required:请求参数中是否必须提供此参数,默认值是true,必须提供
			defaultValue:默认值
	*/
    //页码默认值选为1,表示第一次访问页面,在前端没有给出页码数据时,默认访问第一页。
    (@RequestParam(value = "pageNum", required = false, defaultValue = "1") 
     Integer pageNum, 
     @RequestParam(value = "pageSize", required = false, defaultValue = "默认页容量") 
     Integer pageSize, 
     //提交方式为model
     Model model){

    //启动分页
    PageHelper.startPage(pageNum, pageSize);
    
    //查出数据
    List<Video> videos = videoService.selectAllVideo();
    
    //创建分页工具对象,并储存集合,这一步不能分开写
    PageInfo<Video> pageInfo = new PageInfo<>(videos);
      
    //在model对象中添加分页数据
    model.addAttribute("pageInfo", pageInfo);

    //此时输出的是:查询sql查出的,第一页的数据,共“默认页容量”条。
    System.out.println(videos);

    return "/WEB-INF/jsp/behind/videoList.jsp";
}

五、编写jsp页面

5.1 遍历数据

    <table>
    	<tr>
        	<th>id</th>
        	<th>title</th>
        	<th>detail</th>
        	<th>time</th>
        	<th>speaker_id</th>
        	<th>play_num</th>
    	</tr>
    	<c:forEach items="${pageInfo.list}" var="video">
        	<tr>
            	<td>${video.id}</td>
            	<td>${video.title}</td>
            	<td>${video.detail}</td>
            	<td>${video.time}</td>
            	<td>${video.speaker}</td>
            	<td>${video.playNum}</td>
        	</tr>
    	</c:forEach>
    </table>

5.2 制作翻页按钮

在标签中添加按钮,注意:三段代码的顺序不可改变!

<%--如果  当前页=总页数  --%>
<c:if test="${pageInfo.pageNum == pageInfo.pages}">
    <a href="/video/list?pageNum=1" >首页</a>							&nbsp;&nbsp;
    <a href="/video/list?pageNum=${pageInfo.pageNum - 1}" >上一页</a>	&nbsp;&nbsp;
</c:if>

<%--如果  当前页<总页数  &&  当前页>1  --%>
<c:if test="${pageInfo.pageNum < pageInfo.pages && pageInfo.pageNum > 1}">
    <a href="/video/list?pageNum=1">首页</a>							&nbsp;&nbsp;
    <a href="/video/list?pageNum=${pageInfo.pageNum - 1}">上一页</a>	&nbsp;&nbsp;
    <a href="/video/list?pageNum=${pageInfo.pageNum + 1}">下一页</a>	&nbsp;&nbsp;
    <a href="/video/list?pageNum=${pageInfo.pages}">末页</a>			&nbsp;&nbsp;
</c:if>

<%--如果  当前页=1  --%>
<c:if test="${pageInfo.pageNum == 1}">
    <a href="/video/list?pageNum=${pageInfo.pageNum + 1}">下一页</a>	&nbsp;&nbsp;
    <a href="/video/list?pageNum=${pageInfo.pages}">末页</a>       	&nbsp;&nbsp;
</c:if>
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在 SSM (Spring + SpringMVC + MyBatis) 框架,你可以使用 MyBatis 的分页插件来实现分页查询。 首先,你需要在 MyBatis 的配置文件启用分页插件: ``` <plugins> <plugin interceptor="org.mybatis.generator.plugins.RowBoundsPlugin"/> </plugins> ``` 然后,在你的 Mapper 接口声明分页查询方法,并使用 MyBatis 的 RowBounds 类来进行分页: ```java public interface UserMapper { List<User> selectByPage(RowBounds rowBounds); } ``` 在你的 Service 层,你可以调用 Mapper 接口的分页查询方法,并传入 RowBounds 对象来实现分页: ```java public class UserService { @Autowired private UserMapper userMapper; public List<User> getUsersByPage(int pageNum, int pageSize) { int offset = (pageNum - 1) * pageSize; RowBounds rowBounds = new RowBounds(offset, pageSize); return userMapper.selectByPage(rowBounds); } } ``` 在你的 Controller 层,你可以调用 Service 层的分页查询方法,并将分页参数作为方法的参数传入: ```java public class UserController { @Autowired private UserService userService; @RequestMapping("/users") public List<User> getUsers(int pageNum, int pageSize) { return userService.getUsersByPage(pageNum, pageSize); } } ``` 你还可以使用第三方的分页插件,比如 PageHelper,它提供了更为简单的分页查询方式。 ### 回答2: 在SSM框架,实现分页查询一般需要以下几个步骤: 1. 在数据库创建对应的数据表,保存需要查询的数据。 2. 在Spring配置文件配置数据源,设置数据库连接信息。 3. 创建实体类(POJO),并映射到数据库的表结构。使用注解指定表名、字段名、主键等信息。 4. 创建数据访问层接口(DAO),定义分页查询的方法。使用注解或者XML文件进行方法的映射。 5. 在数据访问层实现类,实现分页查询的方法。使用MyBatis提供的分页插件PageHelper完成分页查询。在方法设置分页参数,如当前页码和每页显示的数量,并调用对应的查询方法。 6. 创建业务逻辑层(Service),调用数据访问层的方法进行分页查询。 7. 在控制层(Controller)接收分页参数,并调用业务逻辑层的方法进行分页查询。将查询结果封装成Page对象,并传递给前端页面。 8. 在前端页面使用分页插件(如Bootstrap的分页插件或jQuery的分页插件)展示分页信息和查询结果。 总结:通过以上步骤,我们可以在SSM框架实现分页查询。使用PageHelper插件可以简化分页查询的操作,提高开发效率。在分页查询时,需要注意设置分页参数,并合理利用数据库的索引等优化查询性能。 ### 回答3: 在SSM框架,可以使用PageHelper插件实现分页查询。 首先,需要在pom.xml文件添加PageHelper的依赖: ``` <dependency> <groupId>com.github.pagehelper</groupId> <artifactId>pagehelper</artifactId> <version>版本号</version> </dependency> ``` 然后,在Spring配置文件配置PageHelper的插件: ``` <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <!-- 配置数据源等其他相关属性 --> <property name="plugins"> <array> <bean class="com.github.pagehelper.PageInterceptor"> <property name="properties"> <!-- 设置数据库方言为MySQL --> <value>dialect=mysql</value> </property> </bean> </array> </property> </bean> ``` 接下来,在需要进行分页查询的方法,使用PageHelper的startPage方法来设置分页参数: ``` PageHelper.startPage(页码, 每页显示数量); ``` 然后,执行查询操作,返回的结果将变为一个分页对象,可以通过该对象获取相关的分页信息和查询结果,比如: ``` List<SomeEntity> list = someMapper.selectByExample(example); PageInfo pageInfo = new PageInfo(list); ``` 在页面上展示分页信息,可以使用PageInfo提供的相关方法,例如获取总记录数、总页数、当前页码、每页显示数量等: ``` pageInfo.getTotal() // 获取总记录数 pageInfo.getPages() // 获取总页数 pageInfo.getPageNum() // 获取当前页码 pageInfo.getPageSize() // 获取每页显示数量 ``` 同时,查询结果也包含在PageInfo对象的列表: ``` List<SomeEntity> resultList = pageInfo.getList(); ``` 通过以上步骤,就可以在SSM框架实现分页查询操作了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值