云数据库和云存储使用

本文涉及的产品
云数据库 MongoDB,独享型 2核8GB
推荐场景:
构建全方位客户视图
函数计算FC,每月15万CU 3个月
简介: 云数据库(数据存储服务)是基于MongoDB托管在云端的数据库,数据以JSON格式存储。作为开发者,您可以在客户端内直接操作数据,也可以在云函数中读写数据。

云数据库使用

云数据库(数据存储服务)是基于MongoDB托管在云端的数据库,数据以JSON格式存储。作为开发者,您可以在客户端内直接操作数据,也可以在云函数中读写数据。

步骤一:设置数据表权限

小程序Serverless提供了一套简明易懂的JSON语法用来控制用户对资源的访问,类似于身份验证体系里的IAM或者网络安全中的ACL。您可以通过修改权限规则来控制数据表权限。
小程序Serverless会为每个新建的数据表自动提供一个默认权限规则。默认新建数据表无任何操作权限,您可以通过添加权限规则管理数据表的权限。
1.打开小程序云控制台,在云数据库页面,单击权限图标15.png
2.在设置数据库权限页面,设置权限规则。然后直接修改安全规则。
3.修改完成后,单击确定
image.png

步骤二:数据库操作

创建数据表
小程序Serverless服务使用的是分布式文件存储数据库MongoDB,以JSON格式存储数据。数据库中的每条记录都是一个JSON格式的对象,一个数据库可以包含多个集合(相当于关系型数据库中的表)。您可以在控制台上创建数据表。
1.打开小程序云控制台,在云数据库页面,选择要关联的环境。
2.点击添加图标14.png,输入数据表名称,最后单击确定
小程序端调用
1.在小程序客户端代码根目录执行以下命令安装 SDK。

npm install @alicloud/mpserverless-sdk --save

2.在 app.js 中初始化SDK(全局只需初始化一次)

// 1. 引入必要的 sdk
import MPServerless from '@alicloud/mpserverless-sdk';
 
// 2. 在 app.js 中对 sdk 进行初始化
// 2.1 初始化 MPServerless
my.serverless = my.serverless || new MPServerless({
  uploadFile: my.uploadFile,
  request: my.request,
  getAuthCode: my.getAuthCode,
}, {
  // 2.2 参数能在小程序云服务空间详情中获取
  appId: '',
  spaceId: '',
  clientSecret: '',
  endpoint: ''
});

3.在小程序页面操作数据库

// 1.添加一条记录
my.serverless.db.collection('users').insertOne({
    name: 'tom',
    age: 1
})
.then(res => {})
.catch(console.error);
// 2.删除一条记录
my.serverless.db.collection('users')
  .deleteOne({
    name: 'Tom'
  })
  .then((res) => {
    const hasDeleted = res.affectedDocs > 0;
  })
  .catch(console.error);
// 3.更新集合中的一条记录
my.serverless.db.collection('users').updateOne({
    name: 'jerry'
}, {
    $set: {
        age: 10
    }
})
.then(res => {})
.catch(console.error);
// 4.查询一条记录
// 调用findOne方法查询大于且最接近18岁的一条记录的name。
//   projection: { name: 1 }表示只返回name字段,其中1表示过滤,0表示排除。
//   sort: { age: 1 }表示将查询后的结果按升序排列,其中1表示升序,-1表示降序。
my.mpserverless.db.collection('users')
  .findOne({
    age: { $gt: 18 }
  }, {
    projection: { name: 1 },
    sort: { age: 1 }
  })
  .then(res => { })
  .catch(console.error);

云函数端调用

// 添加一条记录
module.exports = async function (ctx) {
  return await ctx.mpserverless.db.collection('users').insertOne({
     name: 'tom',
      age: 1
  });
};

数据库常用语法说明

数据存储服务是基于MongoDB托管在云端的数据库,使用MongoDB 3.4版本,常用的数据库操作语法如下。
聚合查询aggregate
计算记录条数count
删除一条数据记录deleteOne
删除一批数据记录deleteMany
获取去重后的记录distinct
查询记录find
查询单条记录findOne
查询并删除一条记录findOneAndDelete
查询并替换一条记录findOneAndReplace
查询并更新记录findOneAndUpdate
替换记录replaceOne
添加一批记录insertMany
添加一条记录insertOne
更新一批记录updateMany
更新一条记录updateOne

设置数据库索引

使用数据库时,对成为查询条件的字段设置索引可以有效提高查询效率,更快的获取信息。缺省情况下会对_id_字段默认创建一个非唯一索引。
1.在数据库页面,单击目标数据表,然后单击索引页签进入索引设置页面。
2.点击添加索引进入索引设置页面。.
3.填写索引名称,设置索引属性、索引字段。

  • 索引属性:可以设置为唯一索引或非唯一索引。

将字段设置为唯一索引后,可以防止不同记录的被索引键上存储相同值。

  • 索引字段:支持单键索引和复合索引设置,字段按升序或降序排列。

单键索引是最常见的索引形式,针对一个指定字段建立索引。对于单字段索引,升序、降序的查询效果一样。

复合索引是是单键索引的升级版,针对多个字段联合创建索引,先按照第一个字段排列,第一个字段相同的记录按第二个字段排列,依次类推。

4.单击保存按钮,保存索引设置。
10.jpeg
11.jpeg

云存储使用

mpserverless.file 对象提供 uploadFiledeleteFile方法管理文件。上传的文件将通过CDN进行网络加速。

步骤一:设置文件权限

小程序Serverless提供了一套简明易懂的JSON语法用来控制用户对资源的访问,类似于身份验证体系里的IAM或者网络安全中的ACL。您可以通过修改权限规则来管理文件权限。

小程序Serverless会为每个新建的文件自动提供一个默认权限规则。默认规则规定所有文件都只有资源所有者可以进行写操作,所有人可读。您可以在控制台上修改文件权限。

1.打开小程序云控制台,在云存储页面,单击权限图标。
2.修改权限规则,然后单击保存
12.jpeg

上面的权限规则由多个子规则组成,每个子规则包含以下信息:

• 范围:用于定义规则生效范围。在数据存储的安全规则中,每一个规则的范围是一个文件(路径)。您可以通过文件路径指定一个特定的文件, 也可以通过JavaScript的正则表达式指代一批文件或使用星号(*)指代所有文件。

• 操作:用于定义生效范围内的特定操作。所有人都具有文件的读权限。.write代表写操作,* 代表所有操作。

• 策略:用于确定生效范围内的特定操作是否允许。默认没有标记为允许的操作,都是不允许的。策略是操作是否被允许的标记,可以是一个布尔值,或者是一个表达式。当策略冲突时,以最先出现的规则策略为准。如默认的权限规则策略表达式request.auth.userId == resource.auth.userId代表所有文件都只有资源所有者可以进行写操作,所有人可读。

步骤二:云存储操作

控制台操作

1.打开小程序云控制台,在云存储页面,单击上传文件
2.单击直接上传或将文件拖拽至上传区域。
文件上传过程中,请勿刷新或关闭页面,否则上传任务会被中断且列表会被清空。
13.jpeg
3.上传成功后,您可以单击详情查看图片下载地址。

小程序端调用

1.在小程序项目的根目录执行以下命令安装 SDK。

npm install @alicloud/mpserverless-sdk --save

2.文件上传或删除。

// 选择文件上传
my.chooseImage({
  chooseImage: 1,
  success: res => {
    const path = res.apFilePaths[0];
    const options = {
      filePath: path,
      headers: {
        contentDisposition: 'attachment',
      },
    };

    my.serverless.file.uploadFile(options).then(console.log).catch(console.error);
  },
});
// 删除之前上传的文件
my.serverless.file.deleteFile('https://resource.bspapp.com/xxx-xx/4b82ded0-0118-4de4-9f50-ab13110a1ffb.jpg').then(res => {
  console.log(res);
}).catch(err => {
  console.error(err);
});

课程作业

支付宝扫码登陆官方小程序【小程序云开发助手】,在 学习 > 训练营打卡作业 > 云数据库和云存储使用 中提交作业。
image.png

相关实践学习
【文生图】一键部署Stable Diffusion基于函数计算
本实验教你如何在函数计算FC上从零开始部署Stable Diffusion来进行AI绘画创作,开启AIGC盲盒。函数计算提供一定的免费额度供用户使用。本实验答疑钉钉群:29290019867
建立 Serverless 思维
本课程包括: Serverless 应用引擎的概念, 为开发者带来的实际价值, 以及让您了解常见的 Serverless 架构模式
相关文章
|
7月前
|
存储 缓存 测试技术
数据库在云存储环境中的配置与优化
【6月更文挑战第6天】探讨数据库在云存储的配置与优化,包括选择合适云服务、设计高效架构、查询语句优化、参数调整、数据分区索引、备份恢复策略、资源监控及性能测试。通过实践与学习,提升应对云环境中的数据库挑战能力。如有问题,欢迎讨论。
82 0
|
存储 JavaScript 前端开发
基于 LeanCloud 的Serverless云存储数据库留言板Demo
基于 LeanCloud 的Serverless云存储数据库留言板Demo
216 0
基于 LeanCloud 的Serverless云存储数据库留言板Demo
|
存储 JavaScript 前端开发
基于 LeanCloud 的Serverless云存储数据库留言板Demo
基于 LeanCloud 的Serverless云存储数据库留言板Demo
85 0
基于 LeanCloud 的Serverless云存储数据库留言板Demo
|
8月前
|
存储 关系型数据库 分布式数据库
PolarDB-CloudJump:优化基于云存储服务的云数据库(发表于VLDB 2022)
我们分析了云存储的性能特征,将它们与本地SSD存储进行了比较,总结了它们对B-tree和LSM-tree类数据库存储引擎设计的影响,并推导出了一个框架CloudJump来指导本地存储引擎迁移到云存储的适配和优化。 并通过PolarDB, RocksDB 两个具体Case 展示优化带来的收益。
144 0
|
存储 缓存 Cloud Native
PolarDB-CloudJump:优化基于云存储服务的云数据库(发表于VLDB 2022)
云数据库实现计算存储分离,支持计算与存储的独立扩展,其用户还可以享受按量付费等特性。这使得基于云数据库的系统更加高效、灵活。因此,构建并使用云原生数据库的势头愈演愈烈。另一方面,云化存储服务已经是云的标准能力,存储侧提供兼容通用的文件接口,并且不对外暴露持久化、容错处理等复杂细节,其易用性和规模化带来的高性价比使得云存储成为了云上系统的第一选择。在通用云存储服务上构建云数据库,无疑是一种既能够享
616 0
|
存储 Serverless 数据库
免费网站部署和免费数据库Serverless云存储资源汇总整理
免费网站部署和免费数据库Serverless云存储资源汇总整理
389 0
免费网站部署和免费数据库Serverless云存储资源汇总整理
|
存储 Serverless 数据库
基于 LeanCloud 的Serverless云存储数据库留言板Demo
基于 LeanCloud 的Serverless云存储数据库留言板Demo
149 0
基于 LeanCloud 的Serverless云存储数据库留言板Demo
|
存储 JavaScript 前端开发
基于 LeanCloud 的Serverless云存储数据库留言板Demo
基于 LeanCloud 的Serverless云存储数据库留言板Demo
164 0
|
存储 Serverless 数据库
免费网站部署和免费数据库Serverless云存储资源汇总整理
免费网站部署和免费数据库Serverless云存储资源汇总整理
150 0
免费网站部署和免费数据库Serverless云存储资源汇总整理
|
11天前
|
存储 Oracle 关系型数据库
数据库传奇:MySQL创世之父的两千金My、Maria
《数据库传奇:MySQL创世之父的两千金My、Maria》介绍了MySQL的发展历程及其分支MariaDB。MySQL由Michael Widenius等人于1994年创建,现归Oracle所有,广泛应用于阿里巴巴、腾讯等企业。2009年,Widenius因担心Oracle收购影响MySQL的开源性,创建了MariaDB,提供额外功能和改进。维基百科、Google等已逐步替换为MariaDB,以确保更好的性能和社区支持。掌握MariaDB作为备用方案,对未来发展至关重要。
39 3