mybatis-javaWeb分页查询

本文介绍了如何在JavaWeb项目中创建一个Brand实体类,以及如何使用Mapper、Service和Servlet进行数据库查询和分页显示。前端页面展示了如何通过Ajax实现数据的动态加载和导航链接的生成。
摘要由CSDN通过智能技术生成

实体类

@Data
@AllArgsConstructor
@NoArgsConstructor
public class Brand implements Serializable {
    private Integer id;

    private String brandName;

    private String companyName;

    private Integer ordered;

    private String description;



    public Brand(String brandName, String companyName, Integer ordered, String description) {
        this.brandName = brandName;
        this.companyName = companyName;
        this.ordered = ordered;
        this.description = description;
    }

    private static final long serialVersionUID = 1L;

}

Mapper

    @Select("select id, brand_name brandName, company_name companyName, ordered, description from tb_brand limit #{start},#{limit}")
    public List<Brand> findAll(@Param("start") int start, @Param("limit") int limit);

Service

    /**
     * 查询所有
     *
     * @return
     */
    @Override
    public List<Brand> findAll(int pageNum, int pageSize) {
        int start = (pageNum - 1) * pageSize;
        int limit = pageSize;
        List<Brand> brands = mapper.findAll(start, limit);
        sqlSession.clearCache();
        return brands;
    }

Servlet

@WebServlet("/BrandServlet")
public class BrandServlet extends HttpServlet {

    private BrandService brandService = new BrandServiceImpl();

    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        this.doPost(req, resp);
    }

    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        //1.接受传递过来的页码
        String num = req.getParameter("pageNum");
        int pageNum = num == null ? 1 : Integer.parseInt(num);

        //2.定义pageSize
        int pageSize = 10;
        //3.查询这一页的信息
        List<Brand> brands = brandService.findAll(pageNum,pageSize);
        //4.调用总页数
        int pageCount = brandService.getPageCount(pageSize);

        //5.将查询到的当前页数据的集合、当前页码、总页数、转发到brand.jsp
        System.err.println("brands.size(): " + brands.size());
        req.setAttribute("brands", brands);
        req.setAttribute("pageNum",pageNum);
        req.setAttribute("pageCount",pageCount);
        req.getRequestDispatcher("brand.jsp").forward(req, resp);
    }
}

前端页面

<table>
    <a href="addbrand.jsp">新增</a>
    <tr>
        <th>编号</th>
        <th>品牌名称</th>
        <th>公司名称</th>
        <th>命令</th>
        <th>描述</th>
        <th>操作</th>
    </tr>
    <c:forEach var="brand" items="${brands}">
        <tr>
            <td>${brand.getId()}</td>
            <td>${brand.getBrandName()}</td>
            <td>${brand.getCompanyName()}</td>
            <td>${brand.getOrdered()}</td>
            <td>${brand.getDescription()}</td>
            <td>
                <a href="DeleteBrandServlet?id=${brand.getId()}">删除</a>
                <a href="updatebrand.jsp?id=${brand.getId()}">修改</a>
            </td>
        </tr>
    </c:forEach>
    
    
    //主要是这下面
    <tr>
        <td colspan="9" align="center">
            <c:if test="${pageNum==1}">
                <label style="color: gray">首页</label>
                <label style="color: gray">上一页</label>
            </c:if>
            <c:if test="${pageNum>1}">
                <a href="BrandServlet?pageNum=1">首页</a>
                <a href="BrandServlet?pageNum=${pageNum-1}">上一页</a>
            </c:if>

            当前页${pageNum}页/共${pageCount}页

            <c:if test="${pageNum<pageCount}">
                <a href="BrandServlet?pageNum=${pageNum+1}">下一页</a>
                <a href="BrandServlet?pageNum=${pageCount}">尾页</a>
            </c:if>
            <c:if test="${pageNum==pageCount}">
                <label style="color: gray">下一页</label>>
                <label style="color: gray">尾页</label>>
            </c:if>
        </td>
    </tr>
</table>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值