首页 > 作文

当查询的数据来自多个数据源,有哪些好的分页策略?

更新时间:2023-04-08 09:54:38 阅读: 评论:0

概述

在业务系统开发中,尤其是后台管理系统,列表页展示的数据来自多个数据源,列表页需要支持分页,怎么解决?

问题

如上图,数据源可能来自不同 db 数据库,可能来自不同 api 接口,也可能来自 db 和 api 的组合。

我这也没有太好的解决方案,接到这样的需求,肯定首先和需求方沟通,这样分页是否合理。

无非就两种方案:

数据定期同步,首先将查询的数据汇总到一个地方,然后再进行查询分页。内存中分页,首先将查询的数据存放到内存,然后再进行查询分页。

如果以某一数据源进行分页,其他字段去其他数据源获取,这样还好处理一些。

如果以多个数据源融合后再分页的话,就数据定期同步 或 内存中分页吧。

数据定期同步方案可以根据实际情况去设计同步频率,至于同步到 es/mysql/mongodb 自己决定即可。

关于内存中分页方案,下面分享两个小方法,供参考。

php 方法

$data = [    0 => ['name' => "姓名1", 'age' => "年龄1"],    1 => ['name' => "姓名2", 'age' => "年龄2"],    2 => ['name' => "姓名3", 'age' => "年龄3"],    3 => ['name' => "姓名4", 'age' => "年龄4"],    4 => ['name' => "姓名5", 'age' => "年龄5"],    5 => ['name' => "姓名6", 'age' => "年龄6"],    6 => ['name' => "姓名7", 'age' => "年龄7"],    7 => ['name' => "姓名8", 'age' => "年龄8"],    8 => ['name' => "姓名9", 'age' => "年龄9"],    9 => ['name' => "姓名10", 'age' => "年龄10"],];/** * 数组分页 * @param array $arraydata 数组数据 * @param int   $page      第几页 * @param int   $pagesize  每页展示条数 * @return array */function arraytopagedata($arraydata = [], $page = 1, $pagesize = 10){    $arraydata = array_values((array)$arraydata);    $pagedata['list'] = array_slice($arraydata, ($page - 1) * $pagesize, $pagesize);    $pagedata['pagination']['total'] = count($arraydata);    $pagedata['pagination']['currentpage'] = $page;    $pagedata['pagination']['prepagecount'] = $pagesize;    return $pagedata;}echo jso消防防火知识n_encode(arraytopagedata($data, 2, 3));

输出:

{    "list": [        {            "name": "姓名4",            "age": "年龄4"        },        {            "name": "姓名5",            "age": "年龄5"        },        {            "name": "姓名6",            "age": "年龄6"        }    ],    "pagination": {        "total": 10,        "currentpage": 2,        "prepagecount": 3    }}

go 方法

pax分之一的导数ckage mainimport ("encoding/json""fmt")type ur []struct {name string `json:"name"`age  string `json:"age"`}type pagination struct {total        int `json:"total"`currentp新亭对泣age  int `json:"currentpage"`prepagecount int `json:"prepagecount"`}type listpagedata struct {list       ur `json:"list"`pagination pagination `json:"pagination"`}func main() {jsonstr := `[{"name": "姓名1","age": "年龄1"},{"name": "姓名2","age": "年龄2"},{"name": "姓名3","age": "年龄3"},{"name": "姓名4","age": "年龄4"},{"name": "姓名5","age": "年龄5"},{"name": "姓名6","age": "年龄6"},{"name": "姓名7","age": "年龄7"},{"name": "姓名8","age": "年龄8"},{"name": "姓名9","age": "年龄9"},{"name": "姓名10","age": "年龄10"}]`var ur urerr := json.unmarshal([]byte(jsonstr), &ur)if err != nil {fmt.println(err.error())}page := 2pagesize := 3pagedata := arrayslice(ur, page, pagesize)listpagedata := listpagedata{}listpagedata.list = pagedatalistpagedata.pagination.total = len(ur)listpagedata.pagination.currentpage = pagelistpagedata.pagination.prepagecount = pagesizejsondata, _ := jsonencode(listpagedata)fmt.println(jsondata)}func jsonencode电视剧星苹果乐园(v interface{}) (string, error) {bytes, err := json.marshal(v)if err != nil {return "", err}return string(bytes), nil}func arrayslice(u u夏娃的爱情r, page int, pagesize int) ur {offt := (page - 1) * pagesizeif offt > int(len(u)) {panic("offt: the offt is less than the length of u")}end := offt + pagesizeif end < int(len(u)) {return u[offt:end]}return u[offt:]}

输出:

{    "list": [        {            "name": "姓名4",            "age": "年龄4"        },        {            "name": "姓名5",            "age": "年龄5"        },        {            "name": "姓名6",            "age": "年龄6"        }    ],    "pagination": {        "total": 10,        "currentpage": 2,        "prepagecount": 3    }}

小结

如果你有更好的方案,欢迎留言评论 ~

推荐阅读

开发流程规范git 分支设计规范api 接口设计规范一线技术管理者究竟在管什么事?一个人被提拔,不仅仅是能力,而是信任

本文发布于:2023-04-08 09:54:36,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/zuowen/b0ec84546e5cfcc2435499db3a6e3beb.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

本文word下载地址:当查询的数据来自多个数据源,有哪些好的分页策略?.doc

本文 PDF 下载地址:当查询的数据来自多个数据源,有哪些好的分页策略?.pdf

标签:姓名   年龄   分页   数据源
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图