评论

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

小程序模糊搜索

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

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

上图只可以实现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方法。
代码都给大家贴出来来,如果对云开发和云数据库还不是很了解的同学可以去翻看下我以前写的文章。

点赞 13
收藏
评论

7 个评论

  • 天空
    天空
    2019-11-09

    很好。谢谢

    2019-11-09
    赞同 1
    回复
  • 雪线
    雪线
    06-08

    简洁,实用,非常好

    06-08
    赞同
    回复
  • 左
    03-12

    请问,如果数据库内储存了字典,如

    course:{
      courseName:'数学',
      teacherName:'陈老师',
    }
    

    能不能搜索courseName?

    03-12
    赞同
    回复 3
    • 国安
      国安
      05-26
      我也在找,请问实现了吗?
      05-26
      回复
    • 左
      05-26回复国安
      直接这样写就可以
      db.collection(‘’).where(
          course:{
              courseName: db.RegExp({
                regexp: '.*' + key,
                options: i,
              })
          }
      }
      05-26
      1
      回复
    • 国安
      国安
      05-26
      谢谢,
      我也找到了,这样写的
       .where({
              “course.courseName”: {
                $regex: key,
                $options: i,
              },
            })
      05-26
      回复
  • -random
    -random
    2019-11-21

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

    2019-11-21
    赞同
    回复 2
    • 编程小石头
      编程小石头
      2019-11-21
      云开发其实就是node.js写的后台
      2019-11-21
      回复
    • 东西EWE
      东西EWE
      2019-12-11回复编程小石头
      请问,如果我要查询的内容在数据库的一个集合的object里面的话,上面代码中的name,address要怎么改?如下图,我要查询的内容在方框内
      2019-12-11
      回复
  • 染柒
    染柒
    2019-11-14

    赞赞赞

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

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

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