[MyBatis]-19 分页查询


prtyaa
prtyaa 2023-12-27 16:19:46 67273
分类专栏: 资讯

分页查询是查询中常用的,一般都是查询到数据量大的时候使用,比如查询到100条数据,但是也面只允许一次显示10条数据,这里就需要用到分页查询

这里是那了一点之前写的配合页面的分页查询代码,实现起来实际上大同小异,可以参考一下

下面就按照整体的过程将代码放入

Mapper

<?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="a">
    <!--分页查询-->
    <select id="selByPage" resultType="com.lin.pojo.User">
         select
          id, login_name loginName, login_pswd loginPswd, name, birthday, reg_time regTime
        from
          tb_user_info
        limit
          #{start},#{size}
    </select>
    
<!--查询总记录数-->
    <select id="countUser" resultType="int">
     select
        COUNT(*)
        from
       tb_user_info
    </select>
</mapper>

Service

public interface UserService {
    /**
     * 分页查询
     *
     * @param page 当前页数
     * @param size 每页显示的记录数
     * @return
     */
    Pagination<User> queryByPage(String page, String size);
}

ServiceImpl

import com.bjsxt.pojo.Pagination;
import com.bjsxt.pojo.User;
import com.bjsxt.service.UserService;
import com.bjsxt.util.MyBatisUtil;
import org.apache.ibatis.session.SqlSession;

import java.util.List;

public class UserServiceImpl implements UserService {
    /**
     * 分页查询
     *
     * @param page 当前页数
     * @param size 每页显示的记录数
     * @return
     */
    @Override
    public Pagination<User> queryByPage(String page, String size) {
        //获取sqlsession 对象
        SqlSession session = MyBatisUtil.getSession();
        //查询总记录数
        int totalCount = session.selectOne("a.countUser");
        //创建分页对象
        Pagination<User> pagination = new Pagination<>(page, size, totalCount);
        //进行分页查询
        List<User> list = session.selectList("a.selByPage", pagination);
        //将结果存到分页对象中
        pagination.setList(list);
        //关闭资源
        session.close();
        //返回
        return pagination;
    }
}

servlet

@WebServlet("/userList.action")
public class UserServlet extends HttpServlet {
    @Override
    protected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        //获取从前台传来的分页参数
        String page = req.getParameter("page");
        String size = req.getParameter("size");
        // 创建service对象
        UserService userService = new UserServiceImpl();
        // 调用方法得到查询结果
        Pagination<User> pagination = userService.queryByPage(page,size);
        // 存放到作用域
        req.setAttribute("pagination", pagination);
        // 页面跳转
        req.getRequestDispatcher("/index.jsp").forward(req, resp);
    }
}

网站声明:如果转载,请联系本站管理员。否则一切后果自行承担。

本文链接:https://www.xckfsq.com/news/show.html?id=31575
赞同 0
评论 0 条
prtyaaL0
粉丝 1 发表 2554 + 关注 私信
上周热门
银河麒麟添加网络打印机时,出现“client-error-not-possible”错误提示  1447
银河麒麟打印带有图像的文档时出错  1364
银河麒麟添加打印机时,出现“server-error-internal-error”  1150
统信桌面专业版【如何查询系统安装时间】  1072
统信操作系统各版本介绍  1069
统信桌面专业版【全盘安装UOS系统】介绍  1027
麒麟系统也能完整体验微信啦!  984
统信【启动盘制作工具】使用介绍  626
统信桌面专业版【一个U盘做多个系统启动盘】的方法  574
信刻全自动档案蓝光光盘检测一体机  483
本周热议
我的信创开放社区兼职赚钱历程 40
今天你签到了吗? 27
信创开放社区邀请他人注册的具体步骤如下 15
如何玩转信创开放社区—从小白进阶到专家 15
方德桌面操作系统 14
我有15积分有什么用? 13
用抖音玩法闯信创开放社区——用平台宣传企业产品服务 13
如何让你先人一步获得悬赏问题信息?(创作者必看) 12
2024中国信创产业发展大会暨中国信息科技创新与应用博览会 9
中央国家机关政府采购中心:应当将CPU、操作系统符合安全可靠测评要求纳入采购需求 8

添加我为好友,拉您入交流群!

请使用微信扫一扫!