使用nhmicro使分库分表支持排序后的分页查询

常见的在创建数据时根据规则分库分表保存,查询时往往只支持按照id进行查询。

Nhmicro(开源地址为 https://github.com/jeffreyning/nh-micro )支持将分库分表中的数据进行分页查询,同时支持排序,支持连续性的向前向后翻页。

原理是根据不同的库分别进行(可带有排序)分页查询,Nhmicro将各个库返回结果合并后,内存中进行二次排序,再次分页后返回给客户端。

这样做可以将查询压力分散到多个读库中,且每个读库可以起不同线程并发查询,提高了查询速度,降低了热点。

 

分库分表合并查询接口:

/NhEsbServiceServlet?cmdName=Groovy&subName=MicroMergeQueryTemplate&groovySubName=getInfoList4Page

 

参数标识

参数名称

样例值

说明

originSql

原始查询sql

select * from <REP_VIEW_NAME> order by col1 desc

<REP_VIEW_NAME>执行时被替换为分表名称

memOrderStr

内存排序str

col1 desc

应该与原始sql中的一致

dbNameList

分库标识

default

配置的microDao实例标识,多个库用逗号分隔。

viewNameList

分表标识

test_merge_1,test_merge_2

每个库中可以有1个或多个分表,但要求每个库中的分表个数一致。

Test_merge_1中数据

 

Test_merge_2中的数据

 

合并查询后分页结果:

 

向后翻页


### 回答1: 垂直分库分表指的是将一个大表按照数据类型或功能模块拆分为多个小表,分别存储在不同的数据库中。 如果需要分页查询,可以使用 limit 和 offset 参数。例如: ``` select * from table limit 10 offset 20; ``` 这表示从第 21 条记录开始查询,查询 10 条记录。 如果分库分表后的数据不再存在于同一个数据库中,可以使用分布式数据库系统,例如 sharding-jdbc,实现分页查询。 ### 回答2: 垂直分库分表是将数据库按照数据的类别或者业务进行划分,以减轻单个数据库的负载并提高系统性能。在垂直分库分表的情况下,如何进行分页查询是一个比较常见的问题。 在进行垂直分库分表后的分页查询,首先需要了解每个分库分表中的数据量和数据分布情况。根据具体的情况,可以选择以下几种不同的分页查询方法: 1. 单库单表分页查询:如果数据量比较小,可以直接在单个分库分表中进行分页查询。通过使用LIMIT和OFFSET等数据库特定的语法,可以指定每页显示的记录数量和查询的起始位置。 2. 多库分页查询:如果数据量较大且分布在多个分库中,可以进行多库分页查询。首先确定要查询的分页范围,即要查询的页数和每页显示的记录数量。然后,根据数据的分布情况,确定需要访问哪些分库,并在每个分库中按照相同的方式进行分页查询。最后,将每个分库的查询结果合并并按照指定的顺序进行排序,得到最终的分页结果。 3. 跳跃查询:在某些特殊情况下,由于数据分布的原因,无法直接使用传统的分页查询方法。此时,可以通过跳跃查询的方式实现分页功能。跳跃查询是指通过在每个分库分表中查询指定范围的数据,并在经过一定的处理后,得到最终的分页结果。 总体而言,垂直分库分表后的分页查询需要根据具体的情况灵活选择合适的查询方法。同时,还需要考虑分页查询的效率和性能问题,例如如何降低跨库查询的开销、如何利用缓存等。在实际应用中,还需要根据实际情况进行性能测试和优化,以提供更好的用户体验。 ### 回答3: 垂直分库分表后的分页查询通常有两种方法。首先是在应用端进行分页查询,其步骤如下: 1. 计算每个分片的数据量:首先需要获取每个分片内的数据总量,可以通过统计每个分片中的记录数量来获得。可以通过连接每个分片的元数据来查询。 2. 计算每个分片需要查询的页数:根据所需的总记录数和每页显示的记录数,可以计算每个分片所需查询的页数。例如,如果总记录数为1000,每页显示10条记录,则每个分片需要查询100页。 3. 在每个分片内进行分页查询:在应用端依次连接每个分片的数据库,按照预先计算好的页数,分别在每个分片内进行分页查询。例如,首先查询第一页的记录,在应用端显示给用户;然后查询第二页的记录,再显示给用户;依此类推,直至显示完所有页。 第二种方法是通过分片中间件进行分页查询,其步骤如下: 1. 在分片中间件中进行配置:在分片中间件中,需要配置所需查询的总记录数,每页显示的记录数,以及每个分片的数据库连接信息等。 2. 发送分页查询请求:应用端发送分页查询请求到分片中间件,同时将所需的页数和每页显示的记录数传递给分片中间件。 3. 分片中间件进行查询:分片中间件根据接收到的查询请求,根据所需的页数,在每个分片的数据库中进行相应的分页查询。 4. 返回分页查询结果:分片中间件将每个分片查询的结果进行合并,然后返回给应用端。 总的来说,无论是在应用端还是分片中间件中进行分页查询,都需要预先计算每个分片的数据量和所需查询的页数,然后按照这些信息进行分页查询操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值