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

news2025/1/13 3:06:23

🚀 作者 :“二当家-小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 => {
        // 返回文件 ID
        console.log(res.fileID)
      },
      fail: err => {
        console.log(err)
      }
    })
  }
})

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

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

结束语

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

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

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

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

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

相关文章

JSP技术讲解

目录 1、JSP简介 2、JSP体验 3、JSP运行原理 4、JSP基本语法 5、JSP指令 6、JSP内置九大对象 7、JSP标签 8、JSP配置 9、JSP排错 10、总结 在前面的Servlet学习中发现Servlet本质是一个java程序,因此Servlet更加擅长编写程序的业务逻辑,而如果要…

Java特性之设计模式【代理模式】

一、代理模式 概述 在代理模式(Proxy Pattern)中,一个类代表另一个类的功能。这种类型的设计模式属于结构型模式 在代理模式中,我们创建具有现有对象的对象,以便向外界提供功能接口 主要解决: 在直接访问…

Apple强大功能:在新款 iPad Pro 和 iPad Air 中释放 M4 芯片潜力

Apple 的最新强大功能:在新款 iPad Pro 和 iPad Air 中释放 M4 芯片的潜力 概述 Apple 推出配备强大 M4 芯片的最新 iPad Pro 和 iPad Air 型号,再次突破创新界限。新一代 iPad 有望彻底改变我们的工作、创造和娱乐方式。凭借无与伦比的处理能力、令人惊…

CTF-reverse,逆向分析,对“左移4或右移4,即(x<<4) | (x >>4)的加密探讨

博主在刷题过程中遇上这样一个有意思的加密(如下图),苦苦思索其逆向运算,被硬控了很久,也没搜到什么资料来解释这个问题(也许是太简单??蒟蒻博主怀疑人生……) 经过博主不…

【MATLAB源码-第205期】基于matlab的LDPC译码算法仿真,对比BF算法,最小和算法,对数BP和概率BP四种算法。

操作环境: MATLAB 2022a 1、算法描述 LDPC 码简介 LDPC码是一种通过稀疏奇偶校验矩阵定义的线性分组码,1962年由Gallager首次提出。这种码具有高效的解码性能,尤其在接近香农极限的情况下,其性能表现尤为突出。LDPC码的核心特…

Logstash分析MySQL慢查询日志实践

删除匹配到的行,当前行信息不记录到message中

VMware Workstation 虚拟机学习 安装centos7.9

1打开VMware Workstation--文件--新建虚拟机 #选择对应的,本例选择最新的 2开始安装centos #网卡配置 vi /etc/sysconfig/network-scripts/ifcfg-ens33 TYPEEthernet PROXY_METHODnone BROWSER_ONLYno BOOTPROTOstatic DEFROUTEyes IPV4_FAILURE_FATALno IPV6INITy…

Linux:进程通信(二)信号的保存

目录 一、信号的处理是否是立即处理的? 二、信号如何保存 1、阻塞、未决、递达 2、信号集 3、信号集操作函数 4、sigprocmask函数 5、sigpending 函数 上篇文章我们讲解了信号的产生:Linux:进程信号(一)信号的产…

【C语言】字符函数和字符串函数--超详解

前言: 在编程的过程中,我们经常要处理字符和字符串,为了⽅便操作字符和字符串,C语⾔标准库中提供了 ⼀系列库函数,接下来我们就学习⼀下这些函数。 1. 字符分类函数 C语⾔中有⼀系列的函数是专⻔做字符分类的&#…

实战BACnet/IP标准通信网关在楼宇自动化中的应用

智慧楼宇建设实现不同设备间的互联互通是一项巨大挑战,尤其是在那些历史悠久的建筑中,新旧系统并存的情况尤为普遍。某大型商业综合体就面临着这样的困境:老旧的暖通空调系统采用Modbus RTU协议,而新部署的能源管理系统却要求BACn…

一文搞懂MySQL索引的数据结构

一、引言 在数据库管理系统中,索引是提高查询性能的关键所在。对于MySQL这类关系型数据库来说,索引更是其优化查询不可或缺的一部分。索引能够大大加快数据的检索速度,减少数据库的I/O操作,提高数据库的整体性能。本文将从索引的…

第2章.STM32开发C语言常用知识点

目录 0. 《STM32单片机自学教程》专栏总纲 2.1. STM32嵌入式开发C语言编程的不同 2.2. C语言常用知识点 2.2.1 位操作 2.2.2 define 宏定义 2.2.3 条件编译 2.2.3.1 #ifdef 2.2.3.2 #ifndef 2.2.3.3 #if !defined 2.2.4 extern 变量声明 2.2.5 typedef 类型别名 …

PPP点对点协议

概述 Point-to-Point Protocol,点到点协议,工作于数据链路层,在链路层上传输网络层协议前验证链路的对端,主要用于在全双工的同异步链路上进行点到点的数据传输。 PPP主要是用来通过拨号或专线方式在两个网络节点之间建立连接、…

Mysql:Before start of result set

解决方法:使用resultSet.getString()之前一定要调用resultSet.next() ResultSet resultSet statement1.executeQuery();while (resultSet.next()){String username1 resultSet.getString("username");int id1 resultSet.getInt…

识货小程序逆向

声明 本文章中所有内容仅供学习交流使用,不用于其他任何目的,抓包内容、敏感网址、数据接口等均已做脱敏处理,严禁用于商业用途和非法用途,否则由此产生的一切后果均与作者无关!wx a15018601872,x30184483x…

java io模型

目录 BIO 模型模型一:单线程服务器模型二:多线程服务器 NIO 模型模型一:遍历轮训 select/poll模型二:基于事件响应机制的 epoll BIO BIO 模型 模型一:单线程服务器 执行过程:阻塞等待 connection&#xff…

JS-拖拽元素放大缩小

效果左右布局&#xff0c;拖拽后&#xff0c;宽度放大缩小 其实自己写也可以&#xff0c;不过还是发现了两个好用的js库&#xff0c;既然不需要自己写&#xff0c;当然是能偷懒就偷懒 1、resizerjs 官网地址&#xff1a;https://github.com/eknowles/resizerjs <!doctype …

SPSS多元线性回归

&#xff08;要满足&#xff09;模型的假设条件需要对数据进行怎样处理&#xff1f;&#xff1f; 为了使数据满足多元线性回归的条件&#xff0c;通常需要进行以下预处理步骤&#xff1a; 1. 数据清洗&#xff1a;处理缺失值、异常值和重复值&#xff0c;确保数据质量。 2. 特…

Linux基础之git与调试工具gdb

目录 一、git的简单介绍和使用方法 1.1 git的介绍 1.2 git的使用方法 1.2.1 三板斧之git add 1.2.2 三板斧之git commit 1.2.3 三板斧之git push 二、gdb的介绍和一些基本使用方法 2.1 背景介绍 2.2 基本的使用方法 一、git的简单介绍和使用方法 1.1 git的介绍 Git是一…

NSSCTF中的web

目录 [第五空间 2021]WebFTP [LitCTF 2023]PHP是世界上最好的语言&#xff01;&#xff01; [SWPUCTF 2021 新生赛]PseudoProtocols [LitCTF 2023]导弹迷踪 [NISACTF 2022]easyssrf [第五空间 2021]WebFTP 1.进入页面&#xff0c;发现是登录页面&#xff0c;想到 弱口令&…