文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

微信小程序多表联合查询的实现详解

2022-11-13 14:00

关注

一对一的设计一般不常见,只需要设计到主表中即可,避免增加复杂性。一对多的关系比较常见,一的一方通常作为主表,多的一方通常作为子表。而多对多一般会拆分成两个一对多的关系,这就必须要用中间表进行过渡。

我们本篇介绍的多表查询,侧重在一对多的关系,我们先看一下我们实际的表设计

一对多表设计

我们实现的是文章关注的业务,通常将文章作为主表,而关注信息作为子表。表和表之间要进行关联,常见的设计思路是子表的外键和主表的主键进行关联

这里的文章表的主键是_id,所谓的主键就是可以唯一标识该条数据,数据不允许重复。关注表的articleid作为关注表的外键,外键可以重复,存储的是主表的主键。

SQL中的关联查询

在sql中可以对表进行关联查询,我们使用select 语句来进行关联,关联的语句为

select * from article a , focus f where a._id = f.articleid

两个表进行关联之后其实是对表进行了合并,将文章表的字段和关注表的字段合并成一个表,关联的条件是文章表的数据标识和关注表的articleid做等值连接

低码中的表关联

低码中的表设计也遵循数据库的表设计,不同的是,低码中的外键不需要自己单独设计,可以设置成关联关系即可,比如文章表的字段

一般我们的数据标识就是我们表的主键,关注表可以存储外键

我们这里的articleid的数据类型设置成关联关系其实就是一种外键的意思。

自定义连接器中实现表关联查询

要想在低码中实现表和表之间的关联查询,需要使用aggregate聚合的语法,聚合语法也有本表和需要连接的表,官方文档里使用了lookup进行表关联

lookup({
from: <要连接的集合名>,
localField: <输入记录的要进行相等匹配的字段>,
foreignField: <被连接集合的要进行相等匹配的字段>,
as: <输出的数组字段名>
})

具体的参数说明

参数字段说明
from要进行连接的另外一个集合的名字
localField当前流水线的输入记录的字段名,该字段将被用于与 from 指定的集合的 foreignField 进行相等匹配。如果输入记录中没有该字段,则该字段的值在匹配时会被视作 null
foreignField被连接集合的字段名,该字段会被用于与 localField 进行相等匹配。如果被连接集合的记录中没有该字段,该字段的值将在匹配时被视作 null
as指定连接匹配出的记录列表要存放的字段名,这个数组包含的是匹配出的来自 from 集合的记录。如果输入记录中本来就已有该字段,则该字段会被覆写

光看文档解释可能还不是特别明白,我们需要具体实践一下

新建连接器

登录控制台,点击自定义连接器,点击新建自定义连接器

输入名称和标识

点击添加方法,新增关联查询的方法

在自定义代码编辑器里输入如下代码

module.exports = async function (params, context) {
  const result = await context.database.collection('lcap-data-2cc504BEZ-gz_necsx6t-preview').aggregate()
  .match({
    openid:params.openid
  })
  .lookup({
    from: 'lcap-data-2cc4oRuu1-wz_hbmrxec-preview',
    localField: 'articleid',
    foreignField: '_id',
    as: 'articles',
  })
  .end()
  // 在这里返回这个方法的结果,需要与出参定义的结构映射
  return result.data;
};

为了让代码运行,先需要新建入参

入参建好之后,在代码里对应的match字段,其中左边是字段标识,右边可以通过params.openid来获取到入参

集合的名称需要在云开发cloudbase的数据库里找

这些都准备好了就要对好localField和foreignField,我们这里的localField是关注表里存储的文章id,而foreignField是文章表的数据标识

入参建好之后需要点击方法测试

测试成功之后就可以点击出参映射,这样一个方法就做好了。这里有必要说一下返回的结果

[

  {

    "_id": "16db756f62e7386d0cfdef132edd5e8a",

    "owner": "1448239235785420802",

    "createdAt": 1659320429844,

    "createBy": "1448239235785420802",

    "wzbs": "111",

    "updateBy": "1448239235785420802",

    "openid": "1111",

    "articleid": "ca780ad562c290d509bd361d555705c3",

    "updatedAt": 1659320429844,

    "articles": [

      {

        "_id": "ca780ad562c290d509bd361d555705c3",

        "owner": "1448239235785420802",

        "createdAt": 1656918229822,

        "bt": "最新文章一",

        "createBy": "1448239235785420802",

        "nr": "<p><span style=\"color:#222222\"><span style=\"font-size:18px\"><span style=\"background-color:#ffffff\">如果你是已经落实工作单位的毕业生,请及时与用人单位签订劳动合同,跟进缴纳社会保险,确认档案转递去向,并在规定时间内办理户口迁移、党团组织关系接转等手续。你入职的企业,也可以申请社会保险补贴、吸纳就业补贴以及扩岗补助等政策支持。</span></span></span></p>",

        "fbrq": 1656864000000,

        "updateBy": "1448239235785420802",

        "updatedAt": 1656918229822

      }

    ]

  }

]

返回的是一个数组,数组里包含一个对象,对象的基本属性是显示的关注表的字段,而articles是具体用户关注的文章的集合,在做展示的时候其实是要绑定articles才对

总结

要想实现多表之间的关联查询,先需要做数据库设计,然后按照文档的聚合语法编写自定义连接器实现,具体还需要结合你自己的业务才可以。

到此这篇关于微信小程序多表联合查询的实现详解的文章就介绍到这了,更多相关小程序多表联合查询内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-前端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯