• PageHelper在Mybatis中的使用


     Mybtis中使用PageHelper中分为2中情况,第一种为采用springboot框架自动生成的Bean方式,第二种为自己数据库配置bean方式,以下分别讲解2种方式的使用:

    一、采用xml形式配置

    1.导入PageHelper的相关jar包

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

    2.在项目根目录添加mybatis.xml文件,并新增如下内容

    <configuration>
      <plugins>
        <plugin interceptor="com.github.pagehelper.PageInterceptor">
        <!-- 设置数据库类型 Oracle,Mysql,MariaDB,SQLite,Hsqldb,PostgreSQL六种数据库 -->
        <!-- <property name="dialect" value="sqlite" /> -->
        </plugin>
       </plugins>
    </configuration>

    3.在项目的yml配置文件中引用mybatis.xml

    # Mybatis配置
    #mybatis:
    # mapperLocations: classpath:mapper/**/*.xml
    # configLocation: classpath:/mybatis.xml

     二、采用JavaBean方式配置

     使用此方式配置则可以不需要mybatis的配置文件,因为此类就相当于之前的配置文件

    1.导入相关jar包

    2. 创建一个配置类并在配置类中添加一个javaBean,在bean中返回sqlSessionFactory方法中添加如下代码

        @Bean(name = "masterSqlSessionFactory")
        public SqlSessionFactory sqlSessionFactory(@Qualifier("masterDataSource") DataSource dataSource) throws Exception {
            SqlSessionFactoryBean factoryBean = new SqlSessionFactoryBean();
            factoryBean.setDataSource(dataSource);
            factoryBean.setTypeAliasesPackage("com.xuanyin.pojo");
            factoryBean.setMapperLocations(new PathMatchingResourcePatternResolver().getResources("classpath:mapper/*.xml"));
            
            //添加PageHelper插件  
            Interceptor interceptor = new PageInterceptor();
            Properties properties = new Properties();
            //数据库
            properties.setProperty("helperDialect", "sqlite");
            //是否将参数offset作为PageNum使用
            properties.setProperty("offsetAsPageNum", "true");
            //是否进行count查询
            properties.setProperty("rowBoundsWithCount", "true");
            //是否分页合理化
            properties.setProperty("reasonable", "false");
            interceptor.setProperties(properties);
            factoryBean.setPlugins(new Interceptor[] {interceptor});
            return factoryBean.getObject();
        }

    三、分页插件使用方法

    方式一:采用Lanmuda表达式形式:不好处理分页查询后的数据

    PageInfo<List<Map<String,Object>>>     pageInfo = PageHelper
                        .startPage(dataItem.getPageNum(),dataItem.getPageSize())
                        .doSelectPageInfo(() -> crossCheckExMapper.queryCrossCheckItemAll(dataItem));

    方式二:采用正常分页形式:此方法分页查询完可整理分页查询数据,查询语句必须在new PageInfo()之前

            //分页获取数据
            PageHelper.startPage(pageNum, pageSize);
            List<Map<String, Object>> questionnaireIds = questionnaireExMapper.getQuestionnaireIds(idsByOrgIds);
            PageInfo<Map<String, Object>> pageInfo = new PageInfo(questionnaireIds);
    
            //整理数据的权限组
            List<Map<String, Object>> result = dealData(queryCondition, questionnaireIds, new ArrayList<>());
            pageInfo.setList(result);

    提示:springboot配置双数据源的时候,由于是自己书写的bean,故此也可以采用此种方式进行进行分页配置,springboot配置双数据源方式,可参考我的另一篇随笔:https://www.cnblogs.com/zblwyj/p/10892903.html

     单数据源自己手动书写bean不会的童鞋也可参考此篇文章。

  • 相关阅读:
    python——时间与时间戳之间的转换
    Python3中正则模块re.compile、re.match及re.search
    javascript 模块化开发
    Python细说 xrange 和 range 的区别
    PyInstaller 生成exe文件
    win10安装mysql5.7.14winx64遇到服务无法启动问题解决方法
    Python 自定义队列 数据结构
    spring事务使用心得
    LS 存取文件
    Single Instance Application
  • 原文地址:https://www.cnblogs.com/zblwyj/p/10893001.html
Copyright © 2020-2023  润新知