评论

小程序云开发模糊查询,实现数据库多字段的模糊搜索

小程序模糊搜索

最近做小程序云开发时,用到了一个数据库的模糊搜索功能,并且是要求多字段的模糊搜索。

网上也有一大堆资源,但是都是单个字段的搜索。如下图

上图只可以实现time字段的模糊搜索。但是我们如果相对数据表里的多个字段做模糊查询呢?该怎么办呢。

多字段模糊搜索

一,如我们的数据表里有以下数据,我们想同时模糊查询name和address字段


如我们搜索“周杰”可以看到我们查询到下面两条数据。

二,如我们搜索“编程”,可以搜索到下面数据


可以看到我们搜索到的两条数据,一个是name字段为 编程小石头,
一个是address字段里包含“编程“ 字样。

下面把代码贴给大家

    let key = "编程小石头";
    console.log("查询的内容", key)
    const db = wx.cloud.database();
    const _ = db.command
    db.collection('qcl').where(_.or([{
        name: db.RegExp({
          regexp: '.*' + key,
          options: 'i',
        })
      },
      {
        address: db.RegExp({
          regexp: '.*' + key,
          options: 'i',
        })
      }
    ])).get({
      success: res => {
        console.log(res)
      },
      fail: err => {
        console.log(err)
      }
    })

key就是我们要搜索的关键字。主要是用到了数据库查询的where,or,get方法。
代码都给大家贴出来来,如果对云开发和云数据库还不是很了解的同学可以去翻看下我以前写的文章。

最后一次编辑于  11-06  
点赞 7
收藏
评论

5 个评论

  • -random
    -random
    11-21

    不错,学到了。 不知道为什么云开发的语法和官方mongodb有点不一样?

    11-21
    赞同
    回复 1
    • 编程小石头
      编程小石头
      11-21
      云开发其实就是node.js写的后台
      11-21
      回复
  • 染柒
    染柒
    11-14

    赞赞赞

    11-14
    赞同
    回复
  • 天空
    天空
    11-09

    麻烦问个问题,我云函数中Update一个Date类型的字段,怎么弄?保持Date类型不改变。谢谢,麻烦解答一下

    11-09
    赞同
    回复
  • 天空
    天空
    11-09

    很好。谢谢

    11-09
    赞同
    回复
  • 📟
    📟
    11-06
    你好大师,请问申请微信支付扫码填写资料,扫码没反应怎么办?昨天到今天一直这样子的,急死人
    11-06
    赞同
    回复 2
    • 📟
      📟
      11-06
      申请微信支付,扫完码,电脑不出申请的单,求大师指点,急
      11-06
      回复
    • 编程小石头
      编程小石头
      11-07回复📟
      官方有时间会挂掉。你今天再试试看。
      11-07
      回复