垂直分表与水平分表2020918

垂直分表

垂直分表适合将表中某些不常用且占了大量空间的列拆分出去。
例如,一张表中的nickname和description字段,假设我们是一个婚恋网站,用户在筛选其他用户的时候,主要使用age和sex两个字段进行查询,而nickname和description两个字段主要用于展示,一般不会在业务查询中用到,description本身又比较长,因此我们可以将这两个字段独立到另一张表中,这样在查询age和sex时,就能带来一定的性能提升。

水平分表

水平分表适合表行数特别大的表,有的公司要求单表行数超过5000万就必须进行分表,这个数字可以作为参考,但并不是绝对标准,关键还是要看表的访问性能。对于一些比较复杂的表,可能超过1000万就要分表了;而对于一些简单的表,即使存储数据超过1亿行,也可以不分表。

1.分页插件

MyBatis Plus自带分页插件,只要简单的配置即可实现分页功能

  • 添加配置类MyBatisPlusConfig

    @Configuration
    @MapperScan("com.atguigu.mybatisplus.mapper")
    public class MyBatisPlusConfig {
          
          
        @Bean
        public MybatisPlusInterceptor mybatisPlusInterceptor(){
          
          
            MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
            //添加分页插件
            interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));
            return interceptor;
        }
    }
    
  • 编写测试方法

    @Test
    public void testPage(){
          
          
        //new Page()中的两个参数分别是当前页码,每页显示数量
        Page<User> page = userMapper.selectPage(new Page<>(1, 2), null);
        List<User> users = page.getRecords();
        users.forEach(System.out::println);
    }
    

2.自定义分页

上面调用的是MyBatis-Plus提供的带有分页的方法,那么我们自己定义的方法如何实现分页呢?

  • UserMapper接口中定义一个方法

    /**
      * 根据年龄查询用户列表,分页显示 
      * @param page 分页对象,xml中可以从里面进行取值,传递参数 Page 即自动分页,必须放在第一位 
      * @param age 年龄 
      * @return 
      */
    Page<User> selectPageVo(@Param("page") Page<User> page,@Param("age") Integer age);
    
  • UserMapper.xml中编写SQL实现该方法

    <select id="selectPageVo" resultType="User">
        select id,username as name,age,email from t_user where age > #{age}
    </select>
    
  • 编写测试方法

    @Test
    public void testPageVo(){
          
          
        Page<User> page = userMapper.selectPageVo(new Page<User>(1,2), 20);
        List<User> users = page.getRecords();
        users.forEach(System.out::println);
    }
    

猜你喜欢

转载自blog.csdn.net/weixin_45688141/article/details/126920427
今日推荐