韦家东 發表於 2023-8-24 00:00:00

Mybatis分页插件的实例详解

<p>
        <strong>Mybatis分页插件的实例详解</strong></p>
<p>
        <strong>1.前言:</strong></p>
<p>
        我们知道,在MySQL中,分页的sql是使用limit来做,如果我们自己写sql,那分页肯定是没有任何问题的。但是一旦model多了起来,复杂了起来,我们很自然的想到使用mybatis的逆向工程来生成相应的po和mapper,但是同时也会带来弊端,比如这里的分页问题就不好解决了。</p>
<p>
          可能有人会说,我可以修改生成的文件,没错,这是可行的,但是一般我们通过逆向工程生成的文件,都不会去动它,所以这个时候,就需要使用分页插件来解决了。</p>
<p>
        如果你也在用Mybatis,建议尝试该分页插件,这个一定是最方便使用的分页插件。</p>
<p>
        该插件目前支持Oracle,Mysql,MariaDB,SQLite,Hsqldb,PostgreSQL六种数据库分页。</p>
<p>
        <strong> 2.使用方法</strong></p>
<p>
        第一步:在Mybatis配置xml中配置拦截器插件:</p>
<div class="jb51code">
        <div>
                <div class="syntaxhighlighterxml" id="highlighter_133027">
                        <div class="toolbar">
                                <span>?</span>
</div>
                        <table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td class="gutter">
                                                        <div class="line number1 index0 alt2">
                                                                1</div>
                                                        <div class="line number2 index1 alt1">
                                                                2</div>
                                                        <div class="line number3 index2 alt2">
                                                                3</div>
                                                        <div class="line number4 index3 alt1">
                                                                4</div>
                                                        <div class="line number5 index4 alt2">
                                                                5</div>
                                                        <div class="line number6 index5 alt1">
                                                                6</div>
                                                        <div class="line number7 index6 alt2">
                                                                7</div>
                                                </td>
                                                <td class="code">
                                                        <div class="container">
                                                                <div class="line number1 index0 alt2">
                                                                        <code class="xml plain">&lt;</code><code class="xml keyword">plugins</code><code class="xml plain">&gt;</code>
</div>
                                                                <div class="line number2 index1 alt1">
                                                                        <code class="xml spaces"> </code><code class="xml comments">&lt;!-- com.github.pagehelper为PageHelper类所在包名 --&gt;</code>
</div>
                                                                <div class="line number3 index2 alt2">
                                                                        <code class="xml spaces"> </code><code class="xml plain">&lt;</code><code class="xml keyword">plugin</code> <code class="xml color1">interceptor</code><code class="xml plain">=</code><code class="xml string">"com.github.pagehelper.PageHelper"</code><code class="xml plain">&gt;</code>
</div>
                                                                <div class="line number4 index3 alt1">
                                                                        <code class="xml spaces">  </code><code class="xml comments">&lt;!-- 设置数据库类型 Oracle,Mysql,MariaDB,SQLite,Hsqldb,PostgreSQL六种数据库--&gt;</code>
</div>
                                                                <div class="line number5 index4 alt2">
                                                                        <code class="xml spaces">  </code><code class="xml plain">&lt;</code><code class="xml keyword">property</code> <code class="xml color1">name</code><code class="xml plain">=</code><code class="xml string">"dialect"</code> <code class="xml color1">value</code><code class="xml plain">=</code><code class="xml string">"mysql"</code><code class="xml plain">/&gt;</code>
</div>
                                                                <div class="line number6 index5 alt1">
                                                                        <code class="xml spaces"> </code><code class="xml plain">&lt;/</code><code class="xml keyword">plugin</code><code class="xml plain">&gt;</code>
</div>
                                                                <div class="line number7 index6 alt2">
                                                                        <code class="xml plain">&lt;/</code><code class="xml keyword">plugins</code><code class="xml plain">&gt;</code>
</div>
                                                        </div>
                                                </td>
                                        </tr></tbody></table>
</div>
        </div>
        <div class="codetool" id="codetool">
                <div class="code_n">
                        <textarea></textarea>
</div>
        </div>
</div>
<p>
        <strong>第二步:在代码中使用</strong></p>
<p>
        1、设置分页信息:</p>
<div class="jb51code">
        <div>
                <div class="syntaxhighlighterxml" id="highlighter_148718">
                        <div class="toolbar">
                                <span>?</span>
</div>
                        <table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td class="gutter">
                                                        <div class="line number1 index0 alt2">
                                                                1</div>
                                                        <div class="line number2 index1 alt1">
                                                                2</div>
                                                        <div class="line number3 index2 alt2">
                                                                3</div>
                                                        <div class="line number4 index3 alt1">
                                                                4</div>
                                                </td>
                                                <td class="code">
                                                        <div class="container">
                                                                <div class="line number1 index0 alt2">
                                                                        <code class="xml plain">//获取第1页,10条内容,默认查询总数count</code>
</div>
                                                                <div class="line number2 index1 alt1">
                                                                        <code class="xml plain">PageHelper.startPage(1, 10);</code>
</div>
                                                                <div class="line number3 index2 alt2">
                                                                        <code class="xml spaces"> </code><code class="xml plain">//紧跟着的第一个select方法会被分页</code>
</div>
                                                                <div class="line number4 index3 alt1">
                                                                        <code class="xml plain">List&lt;</code><code class="xml keyword">Country</code><code class="xml plain">&gt; list = countryMapper.selectIf(1);</code>
</div>
                                                        </div>
                                                </td>
                                        </tr></tbody></table>
</div>
        </div>
        <div class="codetool" id="codetool">
                <div class="code_n">
                        <textarea></textarea>
</div>
        </div>
</div>
<p>
        2、取分页信息</p>
<div class="jb51code">
        <div>
                <div class="syntaxhighlighterxml" id="highlighter_510254">
                        <div class="toolbar">
                                <span>?</span>
</div>
                        <table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td class="gutter">
                                                        <div class="line number1 index0 alt2">
                                                                1</div>
                                                        <div class="line number2 index1 alt1">
                                                                2</div>
                                                        <div class="line number3 index2 alt2">
                                                                3</div>
                                                </td>
                                                <td class="code">
                                                        <div class="container">
                                                                <div class="line number1 index0 alt2">
                                                                        <code class="xml plain">//分页后,实际返回的结果list类型是Page&lt;</code><code class="xml keyword">E</code><code class="xml plain">&gt;,如果想取出分页信息,需要强制转换为Page&lt;</code><code class="xml keyword">E</code><code class="xml plain">&gt;,</code>
</div>
                                                                <div class="line number2 index1 alt1">
                                                                        <code class="xml plain">Page&lt;</code><code class="xml keyword">Country</code><code class="xml plain">&gt; listCountry = (Page&lt;</code><code class="xml keyword">Country</code><code class="xml plain">&gt;)list;</code>
</div>
                                                                <div class="line number3 index2 alt2">
                                                                        <code class="xml plain">listCountry.getTotal();</code>
</div>
                                                        </div>
                                                </td>
                                        </tr></tbody></table>
</div>
        </div>
        <div class="codetool" id="codetool">
                <div class="code_n">
                        <textarea></textarea>
</div>
        </div>
</div>
<p>
        3、取分页信息的第二种方法</p>
<div class="jb51code">
        <div>
                <div class="syntaxhighlighterxml" id="highlighter_930501">
                        <div class="toolbar">
                                <span>?</span>
</div>
                        <table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td class="gutter">
                                                        <div class="line number1 index0 alt2">
                                                                1</div>
                                                        <div class="line number2 index1 alt1">
                                                                2</div>
                                                        <div class="line number3 index2 alt2">
                                                                3</div>
                                                        <div class="line number4 index3 alt1">
                                                                4</div>
                                                        <div class="line number5 index4 alt2">
                                                                5</div>
                                                        <div class="line number6 index5 alt1">
                                                                6</div>
                                                        <div class="line number7 index6 alt2">
                                                                7</div>
                                                        <div class="line number8 index7 alt1">
                                                                8</div>
                                                        <div class="line number9 index8 alt2">
                                                                9</div>
                                                        <div class="line number10 index9 alt1">
                                                                10</div>
                                                        <div class="line number11 index10 alt2">
                                                                11</div>
                                                        <div class="line number12 index11 alt1">
                                                                12</div>
                                                        <div class="line number13 index12 alt2">
                                                                13</div>
                                                        <div class="line number14 index13 alt1">
                                                                14</div>
                                                        <div class="line number15 index14 alt2">
                                                                15</div>
                                                        <div class="line number16 index15 alt1">
                                                                16</div>
                                                        <div class="line number17 index16 alt2">
                                                                17</div>
                                                        <div class="line number18 index17 alt1">
                                                                18</div>
                                                        <div class="line number19 index18 alt2">
                                                                19</div>
                                                </td>
                                                <td class="code">
                                                        <div class="container">
                                                                <div class="line number1 index0 alt2">
                                                                        <code class="xml plain">//获取第1页,10条内容,默认查询总数count</code>
</div>
                                                                <div class="line number2 index1 alt1">
                                                                        <code class="xml plain">PageHelper.startPage(1, 10);</code>
</div>
                                                                <div class="line number3 index2 alt2">
                                                                        <code class="xml plain">List&lt;</code><code class="xml keyword">Country</code><code class="xml plain">&gt; list = countryMapper.selectAll();</code>
</div>
                                                                <div class="line number4 index3 alt1">
                                                                        <code class="xml plain">//用PageInfo对结果进行包装</code>
</div>
                                                                <div class="line number5 index4 alt2">
                                                                        <code class="xml plain">PageInfo page = new PageInfo(list);</code>
</div>
                                                                <div class="line number6 index5 alt1">
                                                                        <code class="xml plain">//测试PageInfo全部属性</code>
</div>
                                                                <div class="line number7 index6 alt2">
                                                                        <code class="xml plain">//PageInfo包含了非常全面的分页属性</code>
</div>
                                                                <div class="line number8 index7 alt1">
                                                                        <code class="xml plain">assertEquals(1, page.getPageNum());</code>
</div>
                                                                <div class="line number9 index8 alt2">
                                                                        <code class="xml plain">assertEquals(10, page.getPageSize());</code>
</div>
                                                                <div class="line number10 index9 alt1">
                                                                        <code class="xml plain">assertEquals(1, page.getStartRow());</code>
</div>
                                                                <div class="line number11 index10 alt2">
                                                                        <code class="xml plain">assertEquals(10, page.getEndRow());</code>
</div>
                                                                <div class="line number12 index11 alt1">
                                                                        <code class="xml plain">assertEquals(183, page.getTotal());</code>
</div>
                                                                <div class="line number13 index12 alt2">
                                                                        <code class="xml plain">assertEquals(19, page.getPages());</code>
</div>
                                                                <div class="line number14 index13 alt1">
                                                                        <code class="xml plain">assertEquals(1, page.getFirstPage());</code>
</div>
                                                                <div class="line number15 index14 alt2">
                                                                        <code class="xml plain">assertEquals(8, page.getLastPage());</code>
</div>
                                                                <div class="line number16 index15 alt1">
                                                                        <code class="xml plain">assertEquals(true, page.isFirstPage());</code>
</div>
                                                                <div class="line number17 index16 alt2">
                                                                        <code class="xml plain">assertEquals(false, page.isLastPage());</code>
</div>
                                                                <div class="line number18 index17 alt1">
                                                                        <code class="xml plain">assertEquals(false, page.isHasPreviousPage());</code>
</div>
                                                                <div class="line number19 index18 alt2">
                                                                        <code class="xml plain">assertEquals(true, page.isHasNextPage());</code>
</div>
                                                        </div>
                                                </td>
                                        </tr></tbody></table>
</div>
        </div>
        <div class="codetool" id="codetool">
                <div class="code_n">
                        <textarea></textarea>
</div>
        </div>
</div>
<p>
        <strong> 3.TestPageHelper</strong></p>
<div class="jb51code">
        <div>
                <div class="syntaxhighlighterxml" id="highlighter_107864">
                        <div class="toolbar">
                                <span>?</span>
</div>
                        <table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td class="gutter">
                                                        <div class="line number1 index0 alt2">
                                                                1</div>
                                                        <div class="line number2 index1 alt1">
                                                                2</div>
                                                        <div class="line number3 index2 alt2">
                                                                3</div>
                                                        <div class="line number4 index3 alt1">
                                                                4</div>
                                                        <div class="line number5 index4 alt2">
                                                                5</div>
                                                        <div class="line number6 index5 alt1">
                                                                6</div>
                                                        <div class="line number7 index6 alt2">
                                                                7</div>
                                                        <div class="line number8 index7 alt1">
                                                                8</div>
                                                        <div class="line number9 index8 alt2">
                                                                9</div>
                                                        <div class="line number10 index9 alt1">
                                                                10</div>
                                                        <div class="line number11 index10 alt2">
                                                                11</div>
                                                        <div class="line number12 index11 alt1">
                                                                12</div>
                                                        <div class="line number13 index12 alt2">
                                                                13</div>
                                                        <div class="line number14 index13 alt1">
                                                                14</div>
                                                        <div class="line number15 index14 alt2">
                                                                15</div>
                                                        <div class="line number16 index15 alt1">
                                                                16</div>
                                                        <div class="line number17 index16 alt2">
                                                                17</div>
                                                        <div class="line number18 index17 alt1">
                                                                18</div>
                                                        <div class="line number19 index18 alt2">
                                                                19</div>
                                                        <div class="line number20 index19 alt1">
                                                                20</div>
                                                </td>
                                                <td class="code">
                                                        <div class="container">
                                                                <div class="line number1 index0 alt2">
                                                                        <code class="xml plain">@Test</code>
</div>
                                                                <div class="line number2 index1 alt1">
                                                                        <code class="xml plain">public void testPageHelper() {</code>
</div>
                                                                <div class="line number3 index2 alt2">
                                                                        <code class="xml spaces"> </code><code class="xml plain">//创建一个spring容器</code>
</div>
                                                                <div class="line number4 index3 alt1">
                                                                        <code class="xml spaces"> </code><code class="xml plain">ApplicationContext applicationContext = new ClassPathXmlApplicationContext("classpath:spring/applicationContext-*.xml");</code>
</div>
                                                                <div class="line number5 index4 alt2">
                                                                        <code class="xml spaces"> </code><code class="xml plain">//从spring容器中获得Mapper的代理对象</code>
</div>
                                                                <div class="line number6 index5 alt1">
                                                                        <code class="xml spaces"> </code><code class="xml plain">TbItemMapper mapper = applicationContext.getBean(TbItemMapper.class);</code>
</div>
                                                                <div class="line number7 index6 alt2">
                                                                        <code class="xml spaces"> </code><code class="xml plain">//执行查询,并分页</code>
</div>
                                                                <div class="line number8 index7 alt1">
                                                                        <code class="xml spaces"> </code><code class="xml plain">TbItemExample example = new TbItemExample();</code>
</div>
                                                                <div class="line number9 index8 alt2">
                                                                        <code class="xml spaces"> </code><code class="xml plain">//分页处理</code>
</div>
                                                                <div class="line number10 index9 alt1">
                                                                        <code class="xml spaces"> </code><code class="xml plain">PageHelper.startPage(2, 10);</code>
</div>
                                                                <div class="line number11 index10 alt2">
                                                                        <code class="xml spaces"> </code><code class="xml plain">List&lt;</code><code class="xml keyword">TbItem</code><code class="xml plain">&gt; list = mapper.selectByExample(example);</code>
</div>
                                                                <div class="line number12 index11 alt1">
                                                                        <code class="xml spaces"> </code><code class="xml plain">//取商品列表</code>
</div>
                                                                <div class="line number13 index12 alt2">
                                                                        <code class="xml spaces"> </code><code class="xml plain">for (TbItem tbItem : list) {</code>
</div>
                                                                <div class="line number14 index13 alt1">
                                                                        <code class="xml spaces">  </code><code class="xml plain">System.out.println(tbItem.getTitle());</code>
</div>
                                                                <div class="line number15 index14 alt2">
                                                                        <code class="xml spaces"> </code><code class="xml plain">}</code>
</div>
                                                                <div class="line number16 index15 alt1">
                                                                        <code class="xml spaces"> </code><code class="xml plain">//取分页信息</code>
</div>
                                                                <div class="line number17 index16 alt2">
                                                                        <code class="xml spaces"> </code><code class="xml plain">PageInfo&lt;</code><code class="xml keyword">TbItem</code><code class="xml plain">&gt; pageInfo = new PageInfo&lt;&gt;(list);</code>
</div>
                                                                <div class="line number18 index17 alt1">
                                                                        <code class="xml spaces"> </code><code class="xml plain">long total = pageInfo.getTotal();</code>
</div>
                                                                <div class="line number19 index18 alt2">
                                                                        <code class="xml spaces"> </code><code class="xml plain">System.out.println("共有商品:"+ total);</code>
</div>
                                                                <div class="line number20 index19 alt1">
                                                                        <code class="xml plain">}</code>
</div>
                                                        </div>
                                                </td>
                                        </tr></tbody></table>
</div>
        </div>
        <div class="codetool" id="codetool">
                <div class="code_n">
                        <textarea></textarea>
</div>
        </div>
</div>
<p>
        感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!</p>
<p>
        原文链接:http://www.cnblogs.com/ganchuanpu/p/6147911.html</p>
頁: [1]
查看完整版本: Mybatis分页插件的实例详解