草庐IT

python - 为 JSON API 选择 RethinkDB 而不是传统 SQL 有多合适?

coder 2023-08-17 原文

关闭。这个问题是opinion-based .它目前不接受答案。












想改善这个问题吗?更新问题,以便可以通过 editing this post 用事实和引文回答问题.

7年前关闭。




Improve this question




我正在为我的网络应用程序构建后端;它将充当前端的 API,并将用 Python(准确地说是 Flask)编写。

在对设计和实现做出一些决定之后,我进入了数据库部分。我开始思考 NoSQL 数据存储是否比传统 SQL 数据库更适合我的项目。以下是应该由数据库处理的基本功能描述,然后是关于我应该选择哪种存储类型的利弊列表。最后是关于为什么我考虑 RethinkDB 而不是其他 NoSQL 数据存储的原因。

API 的基本功能

API 仅包含几个模型:Artist , Song , Suggestion , UserUserArtists .

我希望能够添加一个 User与一些相关数据并链接一些 Artist对它。我要加Song转至 Artist s 根据要求,并生成 Suggestion对于 User ,其中将包含 Artist和一个 Song .

也许最重要的部分之一是 Artist s 将定期链接到 User s (还有 Artist s 可以从系统中删除——因此也可以从 User s 中删除——如果它们不满足某些标准)。 Song s 也将动态添加到 Artist s。这一切意味着User s 没有固定的 Artist s 和也不做 Artist s 有一套固定的 Song s - 他们将不断更新。

优点

对于 NoSQL:

  • 灵活的模式,因为不是每个 Artist将有一个 FacebookID 或 Song SoundcloudID;
  • 虽然是 JSON API,但我相信我会受益于记录存储为 JSON 的事实;
  • 相信数量Song s,尤其是 Suggestion s 会提高很多,因此 NoSQL 会在这里做得更好;

  • 对于 SQL:
  • 它的固定模式可能会在模型之间的关系中派上用场;
  • Flask 支持 SQLAlchemy,这对定义模型非常有帮助;

  • 缺点

    对于 NoSQL:
  • 关系更难实现,更新模型事务类涉及一些代码;
  • Flask 没有任何包装器或模块来简化事情,因此我需要实现某种包装器来帮助我在执行数据库操作时使代码更具可读性;
  • 我不确定我应该如何存储我的记录,尤其是 UserArtist s

  • 对于 SQL:
  • 操作很庞大,我必须定义模式,检查列是否有默认值,分配默认值,验证数据,开始/提交事务——我认为对于像 API 这样简单的东西来说太麻烦了;

  • 为什么要重新思考数据库?

    由于以下原因,我已经考虑将 RehinkDB 用于我的 API 的 NoSQL 的可能实现:
  • 它看起来比其他解决方案更简单、更轻巧;
  • 它具有原生 Python 支持,这是一个很大的优势;
  • 它实现了表连接和其他可以在我的 API 中派上用场的东西,它在模型之间有一些关系;
  • 这是相当新的,我看到了社区的很多含义和爱。还有人愿意不断添加利用数据库交互的新事物。

  • 所有这些都被考虑在内,我很高兴听到关于 NoSQL 或 SQL 是否更适合我的需求的任何建议,以及两者的任何其他优点/缺点,当然,还有一些我没有说的更正适本地。

    最佳答案

    我在 RethinkDB 工作,但这是我作为 Web 开发人员的公正答案(至少尽可能公正)。

  • 从开发人员的角度来看,灵活的模式很好(在你的情况下)。就像您说的那样,使用 PostgreSQL 之类的东西,您必须格式化从第三方(SoundCloud、Facebook 等)提取的所有数据。虽然这并不是一件很难的事情,但也不是一件令人愉快的事情。
  • 能够加入表,对我来说是做事的自然方式(比如用户/用户艺术家/艺术家)。虽然您可以拥有一个用户包含艺术家的结构,但是当您需要检索艺术家并为他们每个人提供一个用户列表时,使用起来会很不愉快。

  • 第一点在 NoSQL 数据库中很常见,而 JOIN 操作更像是 SQL 数据库的事情。
    您可以将 RethinkDB 视为提供每个世界中最好的东西。

    我相信使用 RethinkDB 进行开发是简单、快速和愉快的,这正是我作为一名 Web 开发人员所追求的。

    然而,您可能需要一件事,而 RethinkDB 没有提供,那就是事务。如果您需要 原子 多个表(或文档——比如你必须在用户之间转账)的更新,你肯定会更好地使用像 PostgreSQL 这样的东西。如果您只需要更新多个表,RethinkDB 可以处理。

    就像你说的,虽然 RethinkDB 是新的,但社区很棒,我们 - 在 RethinkDB - 非常关心我们的用户。

    如果您有更多问题,我很乐意回答:)

    关于python - 为 JSON API 选择 RethinkDB 而不是传统 SQL 有多合适?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20597590/

    有关python - 为 JSON API 选择 RethinkDB 而不是传统 SQL 有多合适?的更多相关文章

    1. python - 如何使用 Ruby 或 Python 创建一系列高音调和低音调的蜂鸣声? - 2

      关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。

    2. ruby-on-rails - 使用 rails 4 设计而不更新用户 - 2

      我将应用程序升级到Rails4,一切正常。我可以登录并转到我的编辑页面。也更新了观点。使用标准View时,用户会更新。但是当我添加例如字段:name时,它​​不会在表单中更新。使用devise3.1.1和gem'protected_attributes'我需要在设备或数据库上运行某种更新命令吗?我也搜索过这个地方,找到了许多不同的解决方案,但没有一个会更新我的用户字段。我没有添加任何自定义字段。 最佳答案 如果您想允许额外的参数,您可以在ApplicationController中使用beforefilter,因为Rails4将参数

    3. ruby - Rails 3 的 RGB 颜色选择器 - 2

      状态:我正在构建一个应用程序,其中需要一个可供用户选择颜色的字段,该字段将包含RGB颜色代码字符串。我已经测试了一个看起来很漂亮但效果不佳的。它是“挑剔的颜色”,并托管在此存储库中:https://github.com/Astorsoft/picky-color.在这里我打开一个关于它的一些问题的问题。问题:请建议我在Rails3应用程序中使用一些颜色选择器。 最佳答案 也许页面上的列表jQueryUIDevelopment:ColorPicker为您提供开箱即用的产品。原因是jQuery现在包含在Rails3应用程序中,因此使用基

    4. Python 相当于 Perl/Ruby ||= - 2

      这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:Pythonconditionalassignmentoperator对于这样一个简单的问题表示歉意,但是谷歌搜索||=并不是很有帮助;)Python中是否有与Ruby和Perl中的||=语句等效的语句?例如:foo="hey"foo||="what"#assignfooifit'sundefined#fooisstill"hey"bar||="yeah"#baris"yeah"另外,类似这样的东西的通用术语是什么?条件分配是我的第一个猜测,但Wikipediapage跟我想的不太一样。

    5. java - 什么相当于 ruby​​ 的 rack 或 python 的 Java wsgi? - 2

      什么是ruby​​的rack或python的Java的wsgi?还有一个路由库。 最佳答案 来自Python标准PEP333:Bycontrast,althoughJavahasjustasmanywebapplicationframeworksavailable,Java's"servlet"APImakesitpossibleforapplicationswrittenwithanyJavawebapplicationframeworktoruninanywebserverthatsupportstheservletAPI.ht

    6. 华为OD机试用Python实现 -【明明的随机数】 2023Q1A - 2

      华为OD机试题本篇题目:明明的随机数题目输入描述输出描述:示例1输入输出说明代码编写思路最近更新的博客华为od2023|什么是华为od,od薪资待遇,od机试题清单华为OD机试真题大全,用Python解华为机试题|机试宝典【华为OD机试】全流程解析+经验分享,题型分享,防作弊指南华为o

    7. 【Java 面试合集】HashMap中为什么引入红黑树,而不是AVL树呢 - 2

      HashMap中为什么引入红黑树,而不是AVL树呢1.概述开始学习这个知识点之前我们需要知道,在JDK1.8以及之前,针对HashMap有什么不同。JDK1.7的时候,HashMap的底层实现是数组+链表JDK1.8的时候,HashMap的底层实现是数组+链表+红黑树我们要思考一个问题,为什么要从链表转为红黑树呢。首先先让我们了解下链表有什么不好???2.链表上述的截图其实就是链表的结构,我们来看下链表的增删改查的时间复杂度增:因为链表不是线性结构,所以每次添加的时候,只需要移动一个节点,所以可以理解为复杂度是N(1)删:算法时间复杂度跟增保持一致查:既然是非线性结构,所以查询某一个节点的时候

    8. python - 如何读取 MIDI 文件、更改其乐器并将其写回? - 2

      我想解析一个已经存在的.mid文件,改变它的乐器,例如从“acousticgrandpiano”到“violin”,然后将它保存回去或作为另一个.mid文件。根据我在文档中看到的内容,该乐器通过program_change或patch_change指令进行了更改,但我找不到任何在已经存在的MIDI文件中执行此操作的库.他们似乎都只支持从头开始创建的MIDI文件。 最佳答案 MIDIpackage会为您完成此操作,但具体方法取决于midi文件的原始内容。一个MIDI文件由一个或多个音轨组成,每个音轨是十六个channel中任何一个上的

    9. 「Python|Selenium|场景案例」如何定位iframe中的元素? - 2

      本文主要介绍在使用Selenium进行自动化测试或者任务时,对于使用了iframe的页面,如何定位iframe中的元素文章目录场景描述解决方案具体代码场景描述当我们在使用Selenium进行自动化测试的时候,可能会遇到一些界面或者窗体是使用HTML的iframe标签进行承载的。对于iframe中的标签,如果直接查找是无法找到的,会抛出没有找到元素的异常。比如近在咫尺的例子就是,CSDN的登录窗体就是使用的iframe,大家可以尝试通过F12开发者模式查看到的tag_name,class_name,id或者xpath来定位中的页面元素,会抛出NoSuchElementException异常。解决

    10. python ffmpeg 使用 pyav 转换 一组图像 到 视频 - 2

      2022/8/4更新支持加入水印水印必须包含透明图像,并且水印图像大小要等于原图像的大小pythonconvert_image_to_video.py-f30-mwatermark.pngim_dirout.mkv2022/6/21更新让命令行参数更加易用新的命令行使用方法pythonconvert_image_to_video.py-f30im_dirout.mkvFFMPEG命令行转换一组JPG图像到视频时,是将这组图像视为MJPG流。我需要转换一组PNG图像到视频,FFMPEG就不认了。pyav内置了ffmpeg库,不需要系统带有ffmpeg工具因此我使用ffmpeg的python包装p

    随机推荐