前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >小程序批量删除云数据库里的数据

小程序批量删除云数据库里的数据

原创
作者头像
编程小石头
修改2019-11-20 17:27:13
2K0
修改2019-11-20 17:27:13
举报

我们用云开发的云数据库存数据,难免会遇到数据过多,或者一些过时数据要删除的需求。之前云开发删除数据库只能一条条的删除。要想批量删除很麻烦,近期云开发推出了批量删除数据的方法。甚至可以稍微改造下实现数据库里某个集合(表)里所有数据的删除操作。

老规矩,先看效果图

  • 如删除工资表中2019年9月份的工资
    可以看到我们成功删除7条数据。
  • 删除所有的工资数据
    可以看到我们把工资表里768条数据,全部删除了。 接下来我们就来看下具体的实现代码

一,先看官方文档如何写的

通过上图可以看到,我们既可以删除单条,又可以删除多条。

通过上图可以看到,我们只能结合where语句才能实现批量删除。

再来看下官方给的demo

一看我们就能知道这是写在云函数里的。所以我们批量删除数据库里的数据,必须是通过云函数来实现批量。

官方文档的地址:https://developers.weixin.qq.com/miniprogram/dev/wxcloud/reference-server-api/database/collection.remove.html

二,我们就结合具体业务来实现批量删除

1, 首先看下我们的工资表里,有yuefen这个字段

比如我们2019年11月所有的人工资填写有误,我们想批量的删除所有 yuefen为 2019.11的数据,对应的代码如下图红色框里的代码。

2,作为一个业务代码,我们肯定要把数据做活

所以定义一个输入框,用来输入你要删除的月份。如下图所示

3,删除所有数据

同样的我们想删除所有数据,也比较依赖where。那门我们删除所有数据,该怎么匹配where语句呢。翻看官方文档,可以看到官方文档有判断某一个字段是否有值。所以我们编写的删除所有数据的代码如下。

这样我们就可以通过判断月份存在,就可以删除所有数据了,因为所有的数据都有月份的。

这样我们就可以实现小程序数据库里数据的批量删除操作了,官方其实也有为我们提供批量更新的操作,感兴趣的同学去官方文档看下就可以了。

https://developers.weixin.qq.com/miniprogram/dev/wxcloud/reference-server-api/database/collection.update.html

完整的云函数源码直接给大家贴出来吧。

代码语言:txt
复制
const cloud = require('wx-server-sdk')
cloud.init({
  env: cloud.DYNAMIC_CURRENT_ENV
})
const db = cloud.database()
exports.main = async(event, context) => {
  let {
    type,
    yuefen
  } = event
  try {
    if (type == 'all') {
      const _ = db.command
      return await db.collection('gongzi').where({
        yuefen: _.exists(true) //只要月份字段存在,就删除
      }).remove()
    } else {
      return await db.collection('gongzi').where({
        yuefen: yuefen
      }).remove()
    }

  } catch (e) {
    console.error(e)
  }
}

后面我会写更多关于小程序,云开发,云数据库的文章,请持续关注。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 老规矩,先看效果图
  • 一,先看官方文档如何写的
  • 二,我们就结合具体业务来实现批量删除
    • 1, 首先看下我们的工资表里,有yuefen这个字段
      • 2,作为一个业务代码,我们肯定要把数据做活
        • 3,删除所有数据
          • 这样我们就可以实现小程序数据库里数据的批量删除操作了,官方其实也有为我们提供批量更新的操作,感兴趣的同学去官方文档看下就可以了。
          相关产品与服务
          数据库
          云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
          领券
          问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档