mybaits 分頁插件 pageHelper5.0.2

本文由黑殼網(wǎng)原創(chuàng)

本文來源mybaits 分頁插件 pageHelper5.0.2~黑殼網(wǎng)

殼叔搞笑一刻

一個老帽兒從未乘過電梯。
這天赞哗,他來到一家飯店,站在電梯門口看見一位老太太進了電梯借卧,過了一會兒泄隔,電梯門又打開了,出來了一位年輕漂亮的姑娘耕蝉,他驚喜過望地想:“哇崔梗,要是把我老婆帶來就好了±菰冢”

d1ecbed9e4c046c2b4f204dd8b6af33e-273a5f9944b13e6cced9f2241eefe42c.jpg
d1ecbed9e4c046c2b4f204dd8b6af33e-273a5f9944b13e6cced9f2241eefe42c.jpg

如果你在找Mybatis的分頁插件蒜魄,那么PageHelper一定會是你的首選。這一定會是使用最方便的分頁插件场躯。這個插件它支持任何復(fù)雜的單表谈为,多表分頁。

今天會詳細介紹 pageHelper的5.0的使用

目前該插件踢关,支持的數(shù)據(jù)庫有

<ol ><li><p>Oracle</p></li><li><p> Mysql</p></li><li><p>MariaDB</p></li><li><p>SQLite</p></li><li><p> Hsqldb</p></li><li><p>PostgreSQL</p></li><li><p>DB2</p></li><li><p>SqlServer(2005,2008)</p></li><li><p>Informix</p></li><li><p>H2</p></li><li><p>SqlServer2012</p></li><li><p>Derby</p></li></ol>

<p>使用 PageHelper 你只需要在 classpath 中包含 <a data-cke-saved- target="_blank">pagehelper-x.x.x.jar</a> 和<a data-cke-saved- target="_blank"> jsqlparser-0.9.5.jar</a>伞鲫。

如果你使用 Maven,你只需要在 pom.xml 中添加下面的依賴:</p>

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

與分頁插件 PageHelper 5.0.0 同時發(fā)布的還有 pagehelper-spring-boot-starter耘成。

如果你使用 Spring Boot榔昔,你只需要在 pom.xml 中添加下面的依賴:

<dependency>
    <groupId>com.github.pagehelper</groupId>
    <artifactId>pagehelper-spring-boot-starter</artifactId>
    <version>1.0.0</version>
</dependency>

有關(guān) pagehelper-spring-boot-starter 的用法可以參考集成示例 <a data-cke-saved- target="_blank">MyBatis-Spring-Boot</a>

接著,在spring-mybatis.xml中是這樣配置:

<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        <!-- 數(shù)據(jù)庫連接池 -->
        <property name="dataSource" ref="dataSource" />
        <!-- 加載mybatis的全局配置文件 -->
        <property name="mapperLocations">
            <array>
                <value>classpath:mapping/*.xml</value>
            </array>
        </property>
        <!-- <property name="configLocation" value="classpath:sqlMapConfig.xml" /> -->
        <property name="plugins">
            <array>
                <bean class="com.github.pagehelper.PageInterceptor">
                    <property name="properties">
                        <value>
                            helperDialect=mysql
                        </value>
                    </property>
                </bean>
            </array>
        </property>
    </bean>

配置結(jié)束后瘪菌,進入正題撒会,創(chuàng)建一個查詢語句,用了pageHelper 查詢語句與之前的一樣师妙。

    select
    <include refid="product"></include>
    from product
    where 1 = 1

查詢一個product 的表

    /**
     * 產(chǎn)品管理界面
     *
     * @param request
     * @param model
     * @return
     */
    @RequestMapping(value = "productManage")
    private String productManage(HttpServletRequest request, Model model, ProductDetail productDetail,
                                 @RequestParam(required = true, defaultValue = "1") Integer page,
                                 @RequestParam(required = false, defaultValue = "10") Integer pageSize) {

        PageHelper.startPage(page, pageSize);
        List<ProductDetail> productDetails = productService.getProductManage(productDetail);

        PageInfo<ProductDetail> p = new PageInfo<ProductDetail>(productDetails);

        /**
         * 返回產(chǎn)品查詢信息
         */
        model.addAttribute("productDetail", productDetail);
        /**
         * 返回產(chǎn)品信息集合
         */
        model.addAttribute("productDetails", productDetails);
        /**
         * 分頁配置信息返回
         */
        model.addAttribute("page", p);
        return "manage/product/productManage";
    }

可以看到诵肛,方法里有兩個參數(shù),前面也說了默穴,這是一個demo怔檩,僅僅只是一個非常簡單的分頁效果。

PageHelper.startPage(page, pageSize);

這段代碼表示蓄诽,程序開始分頁了薛训,page默認值是1,pageSize默認是10仑氛,意思是從第1頁開始乙埃,每頁顯示10條記錄闸英。

PageInfo這個類是插件里的類,這個類里面的屬性還是值得看一看:

    //當前頁
    private int pageNum;
    //每頁的數(shù)量
    private int pageSize;
    //當前頁的數(shù)量
    private int size;

    //由于startRow和endRow不常用介袜,這里說個具體的用法
    //可以在頁面中"顯示startRow到endRow 共size條數(shù)據(jù)"

    //當前頁面第一個元素在數(shù)據(jù)庫中的行號
    private int startRow;
    //當前頁面最后一個元素在數(shù)據(jù)庫中的行號
    private int endRow;
    //總記錄數(shù)
    private long total;
    //總頁數(shù)
    private int pages;
    //結(jié)果集
    private List<T> list;

    //前一頁
    private int prePage;
    //下一頁
    private int nextPage;

    //是否為第一頁
    private boolean isFirstPage = false;
    //是否為最后一頁
    private boolean isLastPage = false;
    //是否有前一頁
    private boolean hasPreviousPage = false;
    //是否有下一頁
    private boolean hasNextPage = false;
    //導(dǎo)航頁碼數(shù)
    private int navigatePages;
    //所有導(dǎo)航頁號
    private int[] navigatepageNums;
    //導(dǎo)航條上的第一頁
    private int navigateFirstPage;
    //導(dǎo)航條上的最后一頁
    private int navigateLastPage;

PageInfo<CityList> p=new PageInfo<CityList>(list);

然后mv.addObject("page", p);

這樣在頁面中就可以通過${page.nextPage}翻到下一頁,

${page.prePage}翻到上一頁,

ok是不是簡單了許多甫何,熱愛編程,學(xué)習(xí)不停止遇伞!

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末辙喂,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖微渠,帶你破解...
    沈念sama閱讀 212,718評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件魏铅,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,683評論 3 385
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來娄琉,“玉大人,你說我怎么就攤上這事吓歇∧跛” “怎么了?”我有些...
    開封第一講書人閱讀 158,207評論 0 348
  • 文/不壞的土叔 我叫張陵城看,是天一觀的道長女气。 經(jīng)常有香客問我,道長测柠,這世上最難降的妖魔是什么炼鞠? 我笑而不...
    開封第一講書人閱讀 56,755評論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮轰胁,結(jié)果婚禮上谒主,老公的妹妹穿的比我還像新娘。我一直安慰自己赃阀,他們只是感情好霎肯,可當我...
    茶點故事閱讀 65,862評論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著榛斯,像睡著了一般观游。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上驮俗,一...
    開封第一講書人閱讀 50,050評論 1 291
  • 那天懂缕,我揣著相機與錄音,去河邊找鬼王凑。 笑死提佣,一個胖子當著我的面吹牛吮蛹,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播拌屏,決...
    沈念sama閱讀 39,136評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼术荤!你這毒婦竟也來了倚喂?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,882評論 0 268
  • 序言:老撾萬榮一對情侶失蹤瓣戚,失蹤者是張志新(化名)和其女友劉穎端圈,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體子库,經(jīng)...
    沈念sama閱讀 44,330評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡舱权,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,651評論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了仑嗅。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片宴倍。...
    茶點故事閱讀 38,789評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖仓技,靈堂內(nèi)的尸體忽然破棺而出鸵贬,到底是詐尸還是另有隱情,我是刑警寧澤脖捻,帶...
    沈念sama閱讀 34,477評論 4 333
  • 正文 年R本政府宣布阔逼,位于F島的核電站,受9級特大地震影響地沮,放射性物質(zhì)發(fā)生泄漏嗜浮。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 40,135評論 3 317
  • 文/蒙蒙 一摩疑、第九天 我趴在偏房一處隱蔽的房頂上張望危融。 院中可真熱鬧,春花似錦未荒、人聲如沸专挪。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,864評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽寨腔。三九已至,卻和暖如春率寡,著一層夾襖步出監(jiān)牢的瞬間迫卢,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,099評論 1 267
  • 我被黑心中介騙來泰國打工冶共, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留乾蛤,地道東北人每界。 一個月前我還...
    沈念sama閱讀 46,598評論 2 362
  • 正文 我出身青樓,卻偏偏與公主長得像家卖,于是被迫代替她去往敵國和親眨层。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 43,697評論 2 351

推薦閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理上荡,服務(wù)發(fā)現(xiàn)趴樱,斷路器,智...
    卡卡羅2017閱讀 134,638評論 18 139
  • Spring Boot 參考指南 介紹 轉(zhuǎn)載自:https://www.gitbook.com/book/qbgb...
    毛宇鵬閱讀 46,778評論 6 342
  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語法酪捡,類相關(guān)的語法叁征,內(nèi)部類的語法,繼承相關(guān)的語法逛薇,異常的語法捺疼,線程的語...
    子非魚_t_閱讀 31,602評論 18 399
  • 昨晚洗澡的時候,突然又想起永罚,沉溺生活啤呼,會暫忘死亡這件事。這從何說起尤蛮? 要從去年圣誕節(jié)聚會說起媳友。去年圣誕節(jié)接到朋友邀...
    YanLiu閱讀 353評論 0 1
  • 開始
    恒甜閱讀 218評論 0 0