云开发数据库与传统数据库的不同

在小程序·云开发中,最核心的便是三大组件:数据库、云存储和云函数,从今天开始,我们将开始隔日更的专栏文章,云开发101,在第一周,我们将从最最核心的数据库开始说起。

云开发数据库简介

首先,我们先来了解一下云开发的数据库,云开发数据库是由云开发团队提供给云开发用户的数据库服务,开发者可以在小程序、云函数等环境中,通过简洁易懂的函数调用,来获取到对应的数据,方便开发者快速完成业务逻辑中关于数据库的部分。

在开发过程中,你可以使用诸如 wx.cloud.database().collection('data').where({"age":10}).get() 这样的方法获取到数据库中的信息,而无需再通过服务端提供的 API 完成数据库请求,将数据查询的权力下放到小程序端,加快应用的迭代效率。

云开发数据库底层技术简介

云开发数据库所使用的是 NoSQL (Not Only SQL)数据库方案中的 MongoDB 数据库。MongoDB 数据库是目前业界发展的最好的 NoSQL 数据库,可以让开发者以 SQL 和 NoSQL 两种方式完成数据库结构的建设,快速完成应用的开发。

NoSQL 与 SQL

我们在传统的 Web 应用开发过程中,大多使用的是 SQL 数据库,如 Oracle、SQLite、MySQL、MSSQL 等,但云开发所使用的 MongoDB 则是完全不同的数据库方案,因此,在进行数据库结构设计时,也有所不同。错误的思考模型,会使得你在后续的应用开发过程中,给自己带来无尽的麻烦。因此,也就有了我们这篇文章,向你介绍 NoSQL 世界的魅力。

Schemaless 带来的特性

在我们使用 SQL 数据库开发时我们需要先行设计好数据库的结构、数据表的结构等,而 NoSQL 型数据库,因此,让我们在开发的时候,也会有了不同的开发模式。我们无需在进行应用开发时,先行添加表结构,我们只需要根据我们自己的使用情况,随时增加、删除新的字段,完成自己的业务需求,也正是这种自由,使得云开发有了快速开发、快速迭代的特性。

云开发数据库结构设计思路

由于云开发所使用的数据库类型与我们所熟悉的数据库类型不同,因此,在开发的时候,我们也要相应的修改我们的数据库结构,以适配 NoSQL 数据库的各项特性,从而降低编程时的复杂度,又好又快的满足自己的业务需求。

和 SQL 数据库不同, MongoDB 数据库由于其存储结构从设计之初便是考虑分布式、多节点存储,其 Best Practice 是「以空间换时间」,因此,在设计应用数据结构时,不要考虑应用的数据存储空间,而是更多思考,如何以更快的速度将数据查询出来。

但是,数据库的设计不能完全追求时间,也要思考编程的复杂程度,平衡时间、空间与编程复杂度,以一个更好的方式完成自己的数据库设计。

举个例子,因为极度追求数据的空间换时间,整个数据系统的多种数据仅设计一个集合,所有的数据都挂在一个集合中,显然是不合理的,这种存储会导致应用后续的迭代造成麻烦。

同样的,极度的不追求空间换时间,也是一种错误的选择,如果你将所有的数据都放在各自的独立集合中,则会造成没有很好的利用 NoSQL 数据库的特性,也会使得你的后续编程变得麻烦。

因此,在使用云开发数据库时,我们需要思考我们的业务发展方向,将可能会用到的场景进行割离,思考应用的数据库结构,从而确保自己的应用在后续开发的时候不出问题。

云开发数据库使用常见问题

在实际的应用中,我们也看到,不少人因为不熟悉 NoSQL 的数据库设计理念,在实际开发过程中,出现了不少的问题,这里我们一一讨论一下。

自建主键属性

在 MongoDB 数据库中,数据存储使用的是 ObjectID,因此,其数据的 ID 并非 1 ,2 ,3 ,4 ,而是一个类似于 a718a0f318d76 hash 值,不少人在开发时,因为认为没有自增的数据,无法完成数据排序,就自行实现了一个自增的 ID,每次新增的时候,都重新查询一遍,获取最新的值以后, 再重新新增数据。

但实际上,我们可以有一种更加优雅和方便的工具来完成这种需求,那就是新增一个字段 created_at,这个字段的值设置为当前时间的时间戳 Timestamp。当你后续需要进行数据按新增的数据进行排序时,可以使用这个字段进行逆序排序,同时,因为这个数据使用的是当前的时间数据,你还可以将其用于数据的「创建于XX年XX月XX日」的功能,完成自己的业务需求。这个数据除了能进行直接的排序,还可以用于后续按日期导出数据,比如筛选出某一个特定时间段的数据。

相比于一个自增的 ID,created_at 更加的简单易用,同时,因为不需要提前获取上一条记录中这个字段的值,可以有效的降低数据的查询次数。

时间存储问题

在我们进行业务逻辑开发时,时间数据的获取是不可或缺的,不少人习惯于使用一个可视化的日期数据,便会将数据库中的日期字段设置为 2019-09-09,以便于在使用时直接输出到数据库中,但实际上在开发过程中,建议大家存储时间戳 Timestamp 来作为具体的时间。

这是因为 2019-09-09 的数据并非一个可以用于排序的字段,在后续开发的过程中,因为你使用的是字符串作为时间,如果你需要将数据进行排序,将会无法排序或出现排序错误的情况;此外,因为你存储的是字符串类型的时间,那么后续如果你的业务需求发生了展示形式的变化,会导致你花费大量的时间去修改所有数据的时间,或者在数据的读取和存储时进行多次格式转换,徒增麻烦。

因此,对于时间存储有需求的,我们一贯建议大家使用时间戳来存储,因为时间戳是一个数字类型的数据,因此可以直接进行大小的比对,同时,因为时间戳的数据是全球统一的,如果你的应用后续有全球化的需求,也可以很好的支持。

无法区分是否要拆分为独立的数据集合存储

在进行云开发的数据应用开发的时候,我们发现,不少开发者的疑问是,我所使用的数据,是否有必要进行独立拆分出一个 Collection 来进行数据存储。

这个问题我们可以以一些简单的问题来判断:

  1. 你所使用的数据是否有排序的需求?
  2. 你所使用的数据是否有修改的需求?
  3. 你所使用的数据除了在此处使用,是否还在其他地方使用?

这里我们举几个例子来说明一下,比如说,我们有一个需求,是为一个内容发布系统的文章新增评论功能,那么我们应该如何完成这部分呢?

如果你的评论数据没有排序、修改,也仅在此处使用,你可以考虑将评论数据放在文章数据中的一个子属性中,这样可以有效的完成数据查询,你在文章进行查询的时候,直接将评论数据查询出来,并进行显示,十分的方便。

如果你的评论数据有排序、修改以及其他地方使用的需求,那么就建议你将评论数据单独存放在一个集合中,以便在后续完成排序、更新和调用,如果此时你将其放在文章数据中,在后续查询时就会有很多问题,操作起来极为不便,给自己徒增烦恼。

当然,具体情况具体分析,如果你在分析完成后,依然没有答案,可以在公众号后台提出你的问题,我们将尽快给您回复。

总结

在本次的文章中,我们分享了云开发所使用的 NoSQL 数据库与传统的 SQL 数据库的区别,以及因为这种区别所带来的开发体验上的不同,理解这些基础内容,将会帮助你更好的应用云开发数据库开发你自己的产品。

如果你对于云开发有任何问题,都欢迎你在文章留言出留下你的疑问,我们将一一解答。

如果你想要了解更多关于云开发CloudBase相关的技术故事/技术实战经验,请扫码关注【腾讯云云开发】公众号~

转载于:https://www.cnblogs.com/CloudBase/p/11510498.html

云开发数据库VS传统数据库丨云开发101相关推荐

  1. 2020云盘点:云数据库冲击传统数据库,擦枪走火看金融

    云数据库的发展,在近三年来获得了长足发展,特别是在2020年真的可谓风生水起. 年度热点话题08 云数据库冲击传统数据库厂商, 金融业成为大家首次擦枪走火的首要阵地 对于云数据库的分析,来自这两个专业 ...

  2. 云原生数据库VS传统数据库

    云原生数据库VS传统数据库 一.前言 二.传统的数据库面临的问题 1.性能瓶颈 2.存储瓶颈 3.迁移成本高 三.云原生数据库的特性 1.分层架构设计 2.资源解耦与池化 3.良好的弹性伸缩能力 4. ...

  3. 云数据库与传统数据库有什么区别

    背景 什么是数据库?传统数据库是依照某种数据模型组织起来并存放二级存储器中的数据集合.这种数据集合具有如下特点:尽可能不重复,以最优方式为某个特定组织的多种应用服务,其数据结构独立于使用它的应用程序, ...

  4. 阿里云数据库与传统数据库有何区别?

    阿里云数据库是什么呢?云数据库与传统数据库有哪些区别呢?很多人对两者之间的概念不是很了解,本文将详细介绍阿里云数据库与传统数据库的区别. 有需要购买阿里云数据库或其它任何产品,领取专属优惠代金券! 领 ...

  5. 阿里云李飞飞:传统数据库步履蹒跚,未来的机会在哪里?

    简介: 日前,阿里云云原生数据库PolarDB和云原生数据仓库AnalyticDB在印度正式上线,当地知名的IT媒体YourStory对阿里云智能数据库事业部总负责人李飞飞博士进行了专访. 在采访中李 ...

  6. Hbase数据库与传统数据库的比较

    HBase的知识点 Mycat备份机制 HMASTER动态感知HregionServer的状态. 基于行的行式数据库 行式读取方式 基于列的列式数据库 传统数据库的特点: 数据是按行存储 没有建立索引 ...

  7. 云开发的数据库权限机制解读丨云开发101

    在使用云开发进行开发时,数据库权限是一个让不少人困扰的部分,四种数据库权限,到底是什么意思?其各自的权限.应用场景都是什么?大多数人对于这个机制,还是模糊的.为了帮助大家进行更好的开发,在涉及到具体的 ...

  8. 时序数据库与传统数据库的优势

    传统关系型数据库存储时序数据的问题 有了时序数据后,该存储在哪里呢?首先我们看下传统的关系型数据库解决方案在存储时序数据时会遇到什么问题. 很多人可能认为在传统关系型数据库上加上时间戳一列就能作为时序 ...

  9. 阿里云PolarDB重大更新:两大技术突破,传统数据库一键迁移上云

    5月21日,阿里云PolarDB发布重大更新,提供传统数据库一键迁移上云能力,可以帮助企业将线下的MySQL.PostgreSQL和Oracle等数据库轻松上云,最快数小时内迁移完成.据估算,云上成本 ...

最新文章

  1. PMVS:多视图匹配经典算法
  2. 重磅直播|基于格雷码结合相移技术的高鲁棒性高效率动态三维面形测量
  3. 700 页的机器学习笔记火了!完整版开放下载
  4. php获取文件名称和扩展名
  5. 后门怎么写隐蔽java_用Java写黑软-后门篇
  6. Python描述性统计示例
  7. 在mybatis中resultMap与resultType的区别
  8. 深度揭秘“蚂蚁双链通”
  9. JavaScript异步编程【上】 -- 同步和异步、事件循环(EventLoop)、微任务和宏任务、回调函数
  10. canvas转化为图片并下载
  11. 李飞飞为什么会离职 Google?
  12. svn图形化控制(svnmanager)
  13. ai模仿声音软件_你准备好跟AI机器成为同事了吗?
  14. java判断两个矩形是否相交_判断矩形相交以及求出相交的区域
  15. 14.Linux/Unix 系统编程手册(上) -- 文件系统
  16. IAR编译仿真时提示“__vector_table symbol not found”
  17. 黑马程序员视频-微信小程序-原生框架——项目搭建
  18. 探究Ptcms小说采集规则
  19. uploadify php 重命名,uploadify与php使用详解
  20. zedgraph显示最小刻度_关于ZedGraph几个难点

热门文章

  1. ftp文档服务器设置,ftp服务器基本设置
  2. java中的locksupport_java中线程的停止以及LockSupport工具类
  3. JS之四舍五入Fixed
  4. if else if else语句格式_你还在用if/else吗?
  5. web前端开发怎么样学习?看这份web前端学习路线
  6. 高效update方案
  7. 使用邮箱注册帐户以及激活
  8. 学习资料(不定更新)
  9. Java 加密 base64 encode
  10. subroutines of perl