微信云小程序快速上手云数据库+云函数+云存储的操作

🚀 作者 :“二当家-小D”

🚀 博主简介:⭐前荔枝FM架构师、阿里资深工程师||曾任职于阿里巴巴担任多个项目负责人,8年开发架构经验,精通java,擅长分布式高并发架构,自动化压力测试,微服务容器化k8s等

🚀 欢迎小伙伴们 点赞👍、收藏⭐、留言💬

🍅文末获取源码联系 配套笔记打包🍅

目录

一、云数据库—不同类型的数据设计

1.1不同类型的数据设计

二、云数据库—获取云数据库的初始化

2.1获取云数据库的初始化—小程序端

2.2获取云数据库初始化—云函数

三、云数据库—调用云函数增加数据

3.1调用云函数增加数据

四、云数据库—调用云函数删除数据

4.1调用云函数删除⼀条数据

4.2调用云函数删除多条数据

五、云数据库—调用云函数更改数据

5.1调用云函数更改数据

5.2原子字段自增

六、云数据库—调用云函数查询数据

6.1调用云函数查询数据

七、云函数本地调试获取数据

7.1云函数本地调试获取数据

八、云存储上传本地图片

8.1云存储上传本地图片

九、云存储下载图片+删除图片

9.1云存储下载图片+删除图片

结束语


一、云数据库—不同类型的数据设计

1.1不同类型的数据设计

二、云数据库—获取云数据库的初始化

2.1获取云数据库的初始化—小程序端
  • 获取默认环境的数据库引用
const db = wx.cloud.database()
  • 获取集合的引⽤
const collection = db.collection('test');
  • 获取集合的数据
const list = collection.get()
  • 示例
    getList() {const db = wx.cloud.database()const collection = db.collection('test');collection.get({success:(res)=>{console.log(res)}})},
  • 注意:不能全量查询,查询数据的权限比较低
2.2获取云数据库初始化—云函数
 // 云函数入口文件const cloud = require('wx-server-sdk')cloud.init({ env: cloud.DYNAMIC_CURRENT_ENV }) // 使用当前云环境const db = cloud.database();const collection = db.collection('test');// 云函数入口函数exports.main = async (event, context) => {return await collection.get()}

三、云数据库—调用云函数增加数据

3.1调用云函数增加数据
  // 云函数入口文件const cloud = require('wx-server-sdk')cloud.init({env: cloud.DYNAMIC_CURRENT_ENV}) // 使用当前云环境const db = cloud.database()const collection = db.collection('test')// 云函数入口函数exports.main = async (event, context) => {return await collection.add({data: {title: '小弟课堂云小程序课程',value: '小程序数据库的增加操作'}})}

四、云数据库—调用云函数删除数据

4.1调用云函数删除⼀条数据
  // 云函数入口文件const cloud = require('wx-server-sdk')cloud.init({env: cloud.DYNAMIC_CURRENT_ENV}) // 使用当前云环境const db = cloud.database()const collection = db.collection('test')// 云函数入口函数exports.main = async (event, context) => {return await collection.doc('e67013a466290e2300b6ffb23e00cb0a').remove()}
4.2调用云函数删除多条数据
// 云函数⼊⼝⽂件
const cloud = require('wx-server-sdk')
cloud.init({env: cloud.DYNAMIC_CURRENT_ENV
}) // 使⽤当前云环境
const db = cloud.database()
const collection = db.collection('test')
// 云函数⼊⼝函数
exports.main = async (event, context) => {return await collection.where({ del:0 }).remove()
}

五、云数据库—调用云函数更改数据

5.1调用云函数更改数据
// 云函数入口文件
const cloud = require('wx-server-sdk')cloud.init({env: cloud.DYNAMIC_CURRENT_ENV
}) // 使用当前云环境
const db = cloud.database()
const collection = db.collection('test')// 云函数入口函数
exports.main = async (event, context) => {return await collection('test').doc('40fc38da66290efd00b68afe4974e894').update({data: {value: 'css'}})
}
5.2原子字段自增
// 云函数入口文件
const cloud = require('wx-server-sdk')cloud.init({env: cloud.DYNAMIC_CURRENT_ENV
}) // 使用当前云环境
const db = cloud.database()
const collection = db.collection('test')
const _ = db.command// 云函数入口函数
exports.main = async (event, context) => {return await collection('test').doc('40fc38da66290efd00b68afe4974e894').update({data: {price: _.inc(10)}})
}

六、云数据库—调用云函数查询数据

6.1调用云函数查询数据
// 云函数入口文件
const cloud = require('wx-server-sdk')cloud.init({env: cloud.DYNAMIC_CURRENT_ENV
}) // 使用当前云环境
const db = cloud.database()
const collection = db.collection('test')
const _ = db.command// 云函数入口函数
exports.main = async (event, context) => {return await collection.where({price: _.gt(30)}).get()
}

七、云函数本地调试获取数据

7.1云函数本地调试获取数据

八、云存储上传本地图片

8.1云存储上传本地图片
wx.chooseMedia({success:res=>{console.log(res)console.log(res.tempFiles[0].tempFilePath)wx.cloud.uploadFile({cloudPath: 'xd.png', // 上传至云端的路径filePath:res.tempFiles[0].tempFilePath, // 小程序临时文件路径success: res => {// 返回文件 IDconsole.log(res.fileID)},fail: err => {console.log(err)}})}
})

九、云存储下载图片+删除图片

9.1云存储下载图片+删除图片
wx.cloud.downloadFile({fileID: 'cloud://xdclass-6ggz6mqu20bbca81.7864-xdclass-6ggz6mqu20bbca81-1325634077/111.jpg', // 文件 IDsuccess: res => {// 返回临时文件路径console.log(res.tempFilePath)},fail: console.error
})
wx.cloud.deleteFile({fileList: ['cloud://xdclass-6ggz6mqu20bbca81.7864-xdclass-6ggz6mqu20bbca81-1325634077/111.jpg'],success: res => {// handle successconsole.log(res.fileList)},fail: console.error
})

结束语

今天的内容讲述了云数据库在小程序开发中的应用,包括不同类型的数据设计、获取初始化、增加、删除、更改以及查询数据等方面。通过调用云函数,我们可以实现对数据库的各种操作,为小程序提供了强大的数据支持和管理能力。此外,还介绍了云存储上传本地图片和下载、删除图片的操作,为小程序的多媒体文件管理提供了便利。希望本文对您在小程序开发中的数据库和存储操作有所帮助。敬请期待下一篇文章,我们将继续分享更多有关小程序开发的实用技巧和经验。

今天的文章就到这里了,还有更多内容下次继续。

资料获取📚
完整代码和笔记已经准备好,如果有问题,可以在评论区留言讨论💬
原创不易,别忘了点赞👍+收藏⭐哦!
点击下方链接即可获取完整资料压缩包🎁,快来领取吧!↓↓↓↓

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/8427.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Options API:选项式 API改成Composition API:组合式 API的留言板

让我欢喜让我忧 改成Composition API:组合式 API的代码&#xff0c; <template><!-- start --><span class"span_checkbox">操作<input type"checkbox" v-model"showInput" value"操作" /></span><…

数据结构与算法学习笔记三---栈和队列的表示和实现(C语言)

目录 前言 一、栈 1.栈的概念 2.栈的表示和实现 1.定义 2.初始化 3.销毁 4.清空 5.栈空 6.栈的长度 7.获取栈顶元素 8.入栈 9.出栈 10.遍历 11.完整代码 二、队列 1.队列的概念 2.队列的链式表示和实现 1.定义 2.初始化 3.销毁 4.清空 5.空队列 6.队列长…

大型语言模型(LLMs)是怎样“学习”的?一封给网络工程师的大模型指南

数字时代&#xff0c;人工智能&#xff08;AI&#xff09;及其相关技术正日益成为许多领域的热门话题。其中&#xff0c;生成式人工智能&#xff08;Gen AI&#xff09;和大型语言模型&#xff08;LLMs&#xff09;引起了广泛的兴趣和讨论。然而&#xff0c;尽管这些术语在科技…

哪些博客类型是最受欢迎的?

在创建博客时&#xff0c;您可能会想到的最常见的问题之一是哪些是最受欢迎的博客类型&#xff1f;有许多不同类型的博客涉及广泛的主题&#xff0c;兴趣和受众。对于一个成功的博客&#xff0c;你需要提前计划并选择适合你的利基市场。在本文中&#xff0c;我们将分享您可以立…

在IDEA中如何用Kafka进行异步处理

在IDEA的项目中使用Kafka进行异步处理 在项目的pom.xml文件中&#xff0c;添加以下依赖&#xff1a; <dependency><groupId>org.apache.kafka</groupId><artifactId>kafka-clients</artifactId><version>2.5.0</version> </dep…

旋转矩阵(将坐标轴旋转)

旋转矩阵&#xff08;将坐标轴旋转&#xff09; 在二维空间中&#xff0c;旋转可以用一个单一的角 定义。作为约定&#xff0c;正角表示逆时针旋转。把笛卡尔坐标的列向量关于原点逆时针旋转的矩阵是&#xff1a; 原坐标系下 坐标系逆时针旋转β 补充 sin(-a) -sin(a) co…

C++中的匿名对象

在C中&#xff0c;匿名对象指的是没有显式命名的临时对象。这些对象通常在表达式中创建并使用&#xff0c;然后很快就被销毁。匿名对象是一种非常有用的编程工具&#xff0c;它们可以用于简化代码、进行函数调用或者作为其他对象的初始化值。 特点和用途 立即销毁&#xff1a…

Python 正则表达式 re.match() 和 re.search() 方法

Python re.match 和 re.search 方法 正文re.match() 方法示例一示例二 re.search()示例一示例二 正文 re.match() 方法 调用方法&#xff1a; re.match(pattern, string, flags0)用法说明&#xff1a; 该函数在字符串的起始位置处进行匹配&#xff0c;若匹配到则返回该值&am…

Google Pixel4手机刷机+Root+逆向环境详细教程

Google Pixel4手机刷机Root逆向环境配置详细教程 刷机工具下载 Windows10、Google Pixel4手机当前安卓10系统、adb工具、要刷的谷歌原生的Android11最新刷机包、安装google usb驱动、美版临时twrp-3.6.0_11-0-flame.img和美版永久twrp-installer-3.6.0_11-0-flame.zip、Magis…

程序员有什么实用神器?

程序员的实用神器 在软件开发的海洋中&#xff0c;程序员的实用神器如同航海中的指南针&#xff0c;帮助他们导航、加速开发、优化代码质量&#xff0c;并最终抵达成功的彼岸。这些工具覆盖了从代码编写、版本控制到测试和部署的各个环节。 程序员常用的一些神器包括&#xf…

C++ map set

一.关联式容器 在初期学过的vector、list、deque、forward_list(C11)等&#xff0c;底层都为线性序列的序列式容器。 关联式容器是用来存储数据的&#xff0c;于序列式容器不同的是&#xff0c;里面存储的是<key,value>结构的键值对&#xff0c;在数据检索时比序列式容…

qiankun实现微前端,vue3为主应用,分别引入vue2和vue3微应用

1、vue3主应用配置 1、安装 qiankun yarn add qiankun # 或者 npm i qiankun -S2、在主应用中注册微应用 import { registerMicroApps, start } from "qiankun" const apps [{ name: vue2App, // 应用名称 xs_yiqing_vue2entry: //localhost:8080, // vue 应用…

apk一键换包名工具

工作需要 手动撸了个一键换包名的工具 1 给AndroidManifest.xml修改包名(修改完成后会覆盖原来的文件) java -jar xmleditor-1.0.jar -pkg [AndroidMainifest.xml] 2 给apk修改包名(修改完成后会在当前目录下生成一个新的apk) java -jar xmleditor-1.0.jar -pkgapk [xxx.ap…

C语言(递归)

Hi~&#xff01;这里是奋斗的小羊&#xff0c;很荣幸各位能阅读我的文章&#xff0c;诚请评论指点&#xff0c;关注收藏&#xff0c;欢迎欢迎~~ &#x1f4a5;个人主页&#xff1a;小羊在奋斗 &#x1f4a5;所属专栏&#xff1a;C语言 本系列文章为个人学习笔记&#x…

数据结构——实现通讯录(附源码)

乐观学习&#xff0c;乐观生活&#xff0c;才能不断前进啊&#xff01;&#xff01;&#xff01; 我的主页&#xff1a;optimistic_chen 我的专栏&#xff1a;c语言 点击主页&#xff1a;optimistic_chen和专栏&#xff1a;c语言&#xff0c; 创作不易&#xff0c;大佬们点赞鼓…

layui的treeTable组件,多层级上传按钮失效的问题解决

现象描述: layui的treeTable 的上传按钮在一层能用&#xff0c;展开后其他按钮正常点击&#xff0c;上传按钮无效。 具体原因没有深究&#xff0c;大概率是展开的子菜单没有被渲染treeTable的done管理到&#xff0c;导致没有重绘上传按钮。 解决方案: 不使用layu的上传组件方法…

C语言常见的动态内存错误及几个经典笔试题以及c/c++内存开辟空间等的介绍

文章目录 前言一、常见的动态内存错误1. 对NULL指针的解引用操作2. 对动态开辟空间的越界访问3. 对非动态开辟内存使用free()4. 使用free释放一块动态开辟内存的一部分5. 对同一块动态内存多次释放6. 动态开辟内存忘记释放&#xff08;内存泄漏&#xff09; 二、几个经典笔试题…

rust容器、迭代器

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家&#xff1a;点击跳转 目录 一&#xff0c;std容器 1&#xff0c;Vec&#xff08;向量、栈&#xff09; 2&#xff0c;VecDeque&#xff08;队列、双端队…

邦注科技 模具保护器 CCD电子眼 专业工业视觉检测设备

模具保护器是一种用于保护模具的设备&#xff0c;可以在塑料压铸和冲床等加工过程中起到保护模具的作用。以下是关于模具保护器在保护塑料压铸和冲床模具方面的应用&#xff1a; 塑料压铸模具保护器&#xff1a; 防止碰撞&#xff1a;在塑料压铸过程中&#xff0c;模具可能会…

Vue 3中,`toRef` 和 `toRefs`

在Vue 3中&#xff0c;toRef 和 toRefs 是两个帮助函数&#xff0c;它们用于从 reactive 对象中提取出响应式的引用。这两个函数在处理复杂的响应式状态或者在组合式API中非常有用。 ### toRef toRef 创建一个 ref 对象&#xff0c;它是一个对于 reactive 对象中某个属性的响…