- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我的学生在使用 ActiveRecord for Sinatra 和 Rails 时遇到了一些困难,但他们最终明白了。
但是,他们在 Sequelize for Node 上完全精疲力尽。
在我看来,Sequelize 和 AR 之间的最大区别在于 AR 是同步的,而 Sequelize 不是。
考虑:
# ActiveRecord
@post = Post.find(2)
render json: @post
// Sequelize
Post.findById(2).then(function(post){
response.json(post);
});
对于像这样的小 Action ,差异仍然可见,但看起来还不错。对于更复杂的查询,很容易发现自己陷入回调 hell 。
所以我的问题是:为什么 ActiveRecord 可以同步,但 JS ORM 不能同步?
我了解同步与异步的缺点。但是同步性的缺点似乎并没有真正伤害到 ActiveRecord。
Sequelize 的困难不仅仅在于您必须编写 .then(function(){})
一千次;理解回调的工作原理也需要对 Javascript 有很大的适应性,并且由于 Sequelize 是 Node 的主要关系 ORM,它使 Node 对初学者来说不太容易上手。有人可能会说“初学者不应该使用 Node”,但是 Rails 已经取得了巨大的成功,因为它努力让新手开发人员可以使用它。
最佳答案
JS ORM 同步是不好的,因为底层执行引擎(Node.js)是基于异步事件循环的 execution model .
Node.js scales well 的唯一原因,尽管是单线程的,但因为它使用非阻塞 IO 并且有一个 active ecosystem与非阻塞异步模型配合良好的库。
正因为如此,与 ruby 应用程序服务器不同,在 ruby 应用程序服务器中,单个进程一次只处理一个请求,node.js 进程可以轻松地将大量请求作为昂贵的 IO 操作(例如从磁盘读取) ,从数据库读取,与外部服务通信)do not block the process .
换句话说,如果 Node 是同步的,那么一个用户的数据库查询将导致服务器“挂起”并且在查询完成之前对所有其他用户无响应。
This post详细阐述了 Node.js 事件循环的细节。
虽然这对于一直在 javascript 中处理回调的网络开发人员来说是直观的,但对于通常不熟悉面向回调的 API 的新开发人员来说,这确实让事情变得困难。然而,Node.js 的一些新进步让事情变得更简单。
特别值得注意的是对生成器和异步/等待函数的支持。使用这些功能,我们可以消除回调金字塔,并使用普通的 try/catch 语法在异步代码中进行错误处理。
使用基于生成器的控制流库,如 co异步代码可以以线性方式编写,利用生成器(最新的 Node.js 版本已经支持)。
虽然异步/等待在 Node.js 中尚未正式可用,但它简化了异步代码 even further ,消除了像 co. 这样的图书馆的需要。使用类似 babel 的转译器这个功能可以用right now - 这就是我建议您考虑在类里面使用的内容。
关于javascript - 为什么同步 SQL 是 "bad"?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33976558/
我们的电脑在使用的过程中,有的小伙伴在上网的时候可能就遇到过系统提示:400 bad request的情况。据小编所知这种情况,大致意思就是出现了错误的请求或者请求不能满足。原因是因为我们请求的语法
您可以尝试清除浏览器缓存 访问一下你的FTP看是否可以登陆 成功解决502 Bad Gateway错误 今天登陆博客,显示502 bad gateway,NGINX最烦人的地方就是经常会出现这个
我想要具有 FIFO 的服务器-客户端模型和客户端获取目录路径,但我收到错误“读:错误地址”和“写:错误地址”。 客户端 服务器错误:“读取:地址错误” 客户端错误:“写入:地址错误” 最佳答案 您可
Agda 手册 Inductive Data Types and Pattern Matching状态: To ensure normalisation, inductive occurrences
我正在使用 maven-compiler-plugin:2.3.2 并且每次我对在导入中具有枚举 (ContentType) 的类进行更改时,我需要使 干净,否则它会给我: ERROR] Failed
我想发布我的第一个 Facebook 应用程序,需要一个隐私政策 URL。 我在我的网站上发布了 privacypolicy.html 页面,但是当我在“应用程序详细信息”中配置它时,我收到了下一条消
vscode 1.45.1版本使用克隆存储库时,我收到“Bad credentials”。最近我在github上换了用户名。可能就是这个原因。我如何告诉vs code?
我正在 Mac OS 终端上创建 cron,代码如下: home.cron 的内容: * * * * * /users/username/desktop/forTrump/script.sh 然后我这
我是新手,所以需要任何帮助,当我要求一个例子时,我的教授给我了这段代码,我希望有一个工作模型...... from numpy import loadtxt import numpy as np fr
我使用 linux 服务器已经有一段时间了,通过使用 cifs 挂载到多个 Windows 共享。 到目前为止,我总是在/etc/fstab 中有一行://IPADDRESS/sharename/mn
请大家帮帮我我正在尝试使用 NUTCH 抓取网站,但它给我错误“java.io.IOException: Job failed!” 我正在运行此命令“bin/nutch solrindex http:
我想创建我的基础业务类,例如 EntityBase,以具有一些常见的行为,例如实现用于跟踪对象更改的接口(interface)(IsNew、IsDirty)和 INotifyPropertyChang
我们最近开发了一个基于 SOA 的站点,但是这个站点在负载过重时最终会出现严重的负载和性能问题。我在这里发布了一个与此问题相关的问题: ASP.NET website becomes unrespon
我们的 Azure 功能已开始返回 502 Bad Gateways,但并非所有调用都返回。我没有使用“间歇性”这个词,因为它总是进行相同类型的调用,但现在总是使用相同的数据。 常规配置 Azure
我假设在字典中进行查找时,它需要散列您提供的 key ,然后使用该散列来查找您要查找的对象。 如果是这样,使用较大的对象作为键是否会显着减慢查找速度或产生其他使用字符串或简单数据类型作为键不会遇到的后
我的代码如下: public static final Condition.ActionCondition ACTION_CONDITION_ACTIVATE = new Condit
大家好,我有一个应用程序和一个表单,我要求用户在其中输入地址,并在文本字段下方显示带有标记的谷歌地图,用户可以在其中将标记拖/放到正确的位置。问题是,在显示 map 的开始时,它只是部分显示而不是全部
给定字节矩阵(所有值在内存中都是 1 位),如果其中至少有一个零,则称其为原始列或“坏”列。查找算法,占用 O(1) 额外内存。 如果没有另一个值(如 -1)或另一个重复矩阵来跟踪已经找到的空值,并且
当我创建一个标准类时,我主要这样做: $test = null; $test->id = 1; $test->name = 'name'; 但是在严格模式下我得到一个错误。 显然正确的做法是: $te
我试图理解为什么将 -O2 -march=native 与 GCC 一起使用会比不使用它们时产生更慢的代码。请注意,我在 Windows 7 下使用 MinGW (GCC 4.7.1)。 这是我的代码
我是一名优秀的程序员,十分优秀!