经过上一篇文章的介绍,大家可以了解到如何在微信小程序开发中通过代码的方式来进行操作云数据库,主要分为以下几个步骤:
在删除之前,首先我得要给大家介绍一下云数据库与关系型数据库的区别,这样大家才能够更好的理解云数据库的删除操作。
首先给大家看一张图:
大家可以看到,在云数据库当中一行记录就是一个 record / doc
,而在关系型数据库当中一行记录就是一条数据,知道了这些之后就可以开始进行删除操作了。
_id
删除在云数据库当中,每一条记录都会有一个 _id
,这个 _id
就是这条记录的唯一标识,所以我们可以通过这个 _id
来进行删除操作。
async onRemoveTap() {
// 从指定集合中找到 id 等于指定ID的那条数据,然后删除
const res = await stuCollection.doc('c0b1b0e260d9c9d900b1b0e2a0d9c9d9').remove()
console.log(res);
},
也是首先通过拿到集合,然后再通过集合拿到指定的记录,最后再通过 remove
方法来进行删除操作, 这个 ID,大家自己去云控制台中获取,获取方式我就真的不多说了。
🐤注意:这个删除操作,微信云开发默认的权限是只有创建者才能够进行删除操作,如果你想要其他人也能够进行删除操作,那么你需要在云控制台中进行设置。 😁默认情况下,数据只能是添加的人才可以删除,其它人是没有权限的,可以在后台根据自己的需求修改权限,这一点大家是需要知道和了解清楚的
我删除不是自己创建的数据,控制台出现了如下的错误:
document.remove:fail document.remove:fail cannot remove document with _id 08bade59659d76d500164ecb5824f337, please make sure that the document exists and you have the corresponding Write permission
该如何解决这个问题呢,我们可以在云控制台中进行设置,默认权限是 仅创建者可读写
,我们可以进行自定义安全规则,这样就可以解决这个问题了。
{
"read": true,
"write": true
}
更改完毕了权限之后我们再来进行删除:
通过集合的 where
方法可以进行条件查询,通过 remove
方法可以进行删除操作,这样就可以实现根据条件删除了。
async onRemoveTap() {
const res = await stuCollection.where({
name: '翠花'
}).remove();
console.log(res);
},
看这种范围的删除,该如何删除之前首先要查阅一下官方文档:https://developers.weixin.qq.com/miniprogram/dev/wxcloud/reference-sdk-api/database/collection/Collection.where.html
通过观察在官方代码当中首先是通过 const _ = db.command
来获取到 command
对象,然后再通过 _.gt
来获取到大于的条件,最后再通过 where
方法来进行查询。
既然如此,那么我们就可以通过 _.gt
来获取到大于的条件,然后再通过 remove
方法来进行删除操作。
async onRemoveTap() {
// 1.拿到条件判断工具对象
const _ = db.command;
const res = await stuCollection.where({
age: _.lt(19)
}).remove();
console.log(res);
},
const _ = db.command;
,通过这个语句我们就可以获取到条件判断工具对象,然后再通过 _.lt
来获取到小于的条件,除了小于之外还有很多的条件,大家可以自己去查阅一下官方文档。
https://developers.weixin.qq.com/miniprogram/dev/wxcloud/reference-sdk-api/database/Command.html
本篇文章内容介绍到这就结束了,我们下期再见,感谢大家的观看,谢谢大家。
🐤如果您对本文有任何疑问或想法,请在评论区留言,我将很乐意与您交流。 🐰您的每一条评论对我都至关重要,我会尽快给予回复。 🎈如果您觉得这篇文章对您有所启发或帮助,请不吝赞赏、收藏或分享。 🎁您的每一个动作都是对我创作的最大鼓励和支持。 👍谢谢您的阅读和陪伴!
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。