一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - springboot整合mybatis分頁攔截器的問題小結

springboot整合mybatis分頁攔截器的問題小結

2021-10-21 10:55貝塔-突突 Java教程

springboot整合mybatis分頁攔截器,分頁攔截實際上就是獲取sql后將sql拼接limit,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧

簡介

又到了吹水時間,是這樣的,今天開發時想將自己寫好的代碼拿來優化,因為不想在開發服弄,怕搞壞了到時候GIT到生產服一大堆問題,然后把它分離到我輪子(工具)項目上,最后運行后發現我獲取List的時候很卡至少10秒,我驚了平時也就我的正常版本是800ms左右(不要看它很久,因為數據量很大,也很正常。),前提是我也知道很慢,就等的確需要優化時,我在放出我優化的plus版本,回到10秒哪里,最開始我剛剛接到這個app項目時,在我用 PageHelper.startPage(page, num);(分頁),還沒等查到的數據封裝(PageInfo)就已經分好頁了,現在換到輪子上就發現了這個問題,它沒有幫我將limit拼接到sql后面,導致我獲取全部,再PageInfo分頁,數據量龐大導致很卡,最后…

10秒:

springboot整合mybatis分頁攔截器的問題小結

正常的:

springboot整合mybatis分頁攔截器的問題小結

springboot整合mybatis分頁攔截器

分頁攔截實際上就是獲取sql后將sql拼接limit

pom.xml

   <!-- 引入分頁插件 -->
        <dependency>
            <groupId>com.github.pagehelper</groupId>
            <artifactId>pagehelper</artifactId>
            <version>5.2.0</version>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.21</version>
        </dependency>

        <dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter</artifactId>
            <version>1.3.2</version>
        </dependency>
         <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid</artifactId>
        </dependency>

yml

spring:
  application:
    name: spring-cloud-dynamic
  datasource:
    #類型
    type: com.alibaba.druid.pool.DruidDataSource
    driver-class-name: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://localhost:3306/f2f?useUnicode=true&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai
    username: root
    password: 

    initial-size: 2
    max-idle: 10
    min-idle: 1
    max-wait: 60000
    max-active: 20 #最大空閑連接數
    #多久進行一次檢測,檢測需要關閉的空閑連接
    time-between-eviction-tuns-millis: 60000

MybatisConfig

/**
 * @author lanys
 * @Description:
 * @date 23/7/2021 下午8:38
 */

@Configuration
@EnableTransactionManagement
@PropertySource(value = "classpath:application.yml", ignoreResourceNotFound = true)
public class MybatisConfig implements TransactionManagementConfigurer {

    @Value("${mybatis.mapper-locations}")
    private String mapper;

    @Value("${mybatis.type-aliases-package}")
    private String aliases;

    @Autowired
    private DataSource dataSource;

    @Bean(name = "sqlSessionFactory")
    public SqlSessionFactory sqlSessionFactory() throws Exception {
        SqlSessionFactoryBean bean = new SqlSessionFactoryBean();
        // 設置數據源
        bean.setDataSource(dataSource);
        // 設置xml
        bean.setMapperLocations(new PathMatchingResourcePatternResolver().getResources(mapper));
        // 設置別名
        bean.setTypeAliasesPackage(aliases);
        // 添加分頁插件
        bean.setPlugins(new Interceptor[]{pageInterceptor()});
        bean.getObject().getConfiguration().setMapUnderscoreToCamelCase(true);
        return bean.getObject();
    }

    /**
     * 分頁攔截器
     * @return
     */
    private PageInterceptor pageInterceptor() {
        PageInterceptor pageInterceptor = new PageInterceptor();
        // 詳見 com.github.pagehelper.page.PageParams
        Properties p = new Properties();
        // RowBounds是否進行count查詢 - 默認不查詢
        p.setProperty("rowBoundsWithCount", "true");
        // 當設置為true的時候,如果page size設置為0(或RowBounds的limit=0),就不執行分頁,返回全部結果
        p.setProperty("pageSizeZero", "true");
        // 分頁合理化
        p.setProperty("reasonable", "false");
        // 是否支持接口參數來傳遞分頁參數,默認false
        p.setProperty("supportMethodsArguments", "true");
        // 設置數據庫方言 , 也可以不設置,會動態獲取
        p.setProperty("helperDialect", "mysql");
        pageInterceptor.setProperties(p);
        return pageInterceptor;
    }

    @Override
    public PlatformTransactionManager annotationDrivenTransactionManager() {
        return new DataSourceTransactionManager(dataSource);
    }
}

測試

自己的其中代碼

/**
     * 關注列表
     * @param userId
     * @param page
     * @param size
     * @return
     */
    @Override
    public List<DynamicInfo> focusList(Long userId, Integer page, Integer size) {
        PageHelper.startPage(page, size);

        List<DynamicInfo> listByUserId = new ArrayList<>();
        try {
            //獲取自己關注列表
            listByUserId = this.dynamicReleaseMapper.getListFocusId(userId);
            if (listByUserId == null || listByUserId.size() == 0){
                return listByUserId;
            }
            //List<DynamicInfo> listByUserId = this.dynamicReleaseMapper.getListFocusId(userId).stream().filter(x->(x.getIsPicture()!=2 && x.getIsVideo() !=2)||(x.getIsPicture()==2 && x.getIsVideo() !=2)||(x.getIsPicture()!=2 && x.getIsVideo() ==2)).collect(Collectors.toList());
            publicGetDynamicInfo(userId,listByUserId);
            //}
            log.info("-------獲取關注列表-------");
            return listByUserId;
        } catch (Exception e) {
            log.error("獲取關注列表異常",e);
        }
        return listByUserId;
    }

想分頁要加 PageHelper.startPage(page, size);,否則會默認不分頁,也可以自己加limit.

結果(sql語句很長截取一部分):

GROUP BY id ORDER BY create_time desc LIMIT ? 

總結

這代碼是最后發現不對后,問公司大佬才懂,瞬間學到了,可能有人會問,這有什么好處嗎?
優點(自己的想法):

1. 直接在數據庫過濾,少了很多處理。為什么?因為如果你先查出全部在進行封裝分頁,看不出什么問題。但是如果你直接獲取后,還要其他處理,比如一個動態,你要獲取最新的動態,動態需要圖片,視頻,標簽,地址等,這一系列獲取,如果獲取到的動態很少還好,如果很多,那個速度自己都覺得可怕(慢)。
2. 運行速度快很多,在開發中,盡量減少訪問數據庫來獲取數據。
3. 省事,有些是在sql后面自己加limit,但是sql語句很多時,也很繁瑣

缺點:
看個人需求,看合不合適

到此這篇關于springboot整合mybatis攔截器分頁的文章就介紹到這了,更多相關springboot整合mybatis分頁內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://blog.csdn.net/qq_44697754/article/details/119045075

延伸 · 閱讀

精彩推薦
  • Java教程Java8中Stream使用的一個注意事項

    Java8中Stream使用的一個注意事項

    最近在工作中發現了對于集合操作轉換的神器,java8新特性 stream,但在使用中遇到了一個非常重要的注意點,所以這篇文章主要給大家介紹了關于Java8中S...

    阿杜7472021-02-04
  • Java教程小米推送Java代碼

    小米推送Java代碼

    今天小編就為大家分享一篇關于小米推送Java代碼,小編覺得內容挺不錯的,現在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧...

    富貴穩中求8032021-07-12
  • Java教程升級IDEA后Lombok不能使用的解決方法

    升級IDEA后Lombok不能使用的解決方法

    最近看到提示IDEA提示升級,尋思已經有好久沒有升過級了。升級完畢重啟之后,突然發現好多錯誤,本文就來介紹一下如何解決,感興趣的可以了解一下...

    程序猿DD9332021-10-08
  • Java教程Java使用SAX解析xml的示例

    Java使用SAX解析xml的示例

    這篇文章主要介紹了Java使用SAX解析xml的示例,幫助大家更好的理解和學習使用Java,感興趣的朋友可以了解下...

    大行者10067412021-08-30
  • Java教程20個非常實用的Java程序代碼片段

    20個非常實用的Java程序代碼片段

    這篇文章主要為大家分享了20個非常實用的Java程序片段,對java開發項目有所幫助,感興趣的小伙伴們可以參考一下 ...

    lijiao5352020-04-06
  • Java教程Java實現搶紅包功能

    Java實現搶紅包功能

    這篇文章主要為大家詳細介紹了Java實現搶紅包功能,采用多線程模擬多人同時搶紅包,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙...

    littleschemer13532021-05-16
  • Java教程Java BufferWriter寫文件寫不進去或缺失數據的解決

    Java BufferWriter寫文件寫不進去或缺失數據的解決

    這篇文章主要介紹了Java BufferWriter寫文件寫不進去或缺失數據的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望...

    spcoder14552021-10-18
  • Java教程xml與Java對象的轉換詳解

    xml與Java對象的轉換詳解

    這篇文章主要介紹了xml與Java對象的轉換詳解的相關資料,需要的朋友可以參考下...

    Java教程網2942020-09-17
主站蜘蛛池模板: 俄罗斯一级毛片免费播放 | 亚洲视频在线观看免费 | 亚洲 欧美 国产 综合 播放 | 五月天精品在线 | 视频一区国产精戏刘婷30 | 四虎影院网站 | 日本道三区播放区 | 欧美精品v日韩精品v国产精品 | 国产福利自产拍在线观看 | 亚洲国产精品久久久久久网站 | 日本国产在线视频 | 精品久久免费观看 | 亚洲欧洲网站 | 日本视频在线观看播放 | 精品国产欧美一区二区五十路 | 日产精品一二三四区国产 | 精品国产区 | 国产日韩欧美在线一二三四 | 国产精品馆| 国内体内she精视频免费 | 99视频免费 | 九九国产在线观看 | 国内精品久久久久久中文字幕 | 69老司机亚洲精品一区 | 无人在线视频高清免费观看动漫 | 好男人社区www影院在线观看 | 18无删减羞羞网站动漫 | 精品麻豆国产 | 亚洲乱码一二三四区国产 | 欧美男同猛男 videos 同性 | 99视频在线观看免费视频 | 九色PORNY真实丨国产免费 | 福利色播 | 日本三级免费网站 | 青青国产成人久久激情91麻豆 | 公园吃女人奶野战视频 | 大陆黄色片 | 欧美高清免费一级在线 | 久青草国产观看在线视频 | v视界影院成片 | 国产一卡二卡四卡免费 |