12

所以我现在一直在玩 NodeJS/Express,我真的很想尝试使用完整的 JavaScript 堆栈重写一个相对较大的副项目,看看它是如何工作的。Sails.js 对于支持 Web 套接字的 REST API 的 NodeJS 后端似乎是一个相当不错的选择,这正是我正在寻找的,但是我想要解决的另一个问题是 NodeJS 中的事务 SQL。

在处理 MySQL 时,我在 NodeJS 方面看到的大多数数据层/orms 似乎都不支持事务。Sails.js (Waterline) 提供的 ORM 似乎也不支持事务,这很奇怪,因为我见过提到它的地方,尽管这些评论已经很老了。Knex.js 支持事务,所以我想知道用它替换 ORM is Sails.js 是否容易(或者 Sails.js 在核心框架中假设 Waterline)。

我还想知道除了 Bookshelf 之外是否还有基于 Knex.js 的 ORM,因为我不是 Backbones Model/Collection 系统的粉丝?

4

3 回答 3

17

您仍然可以直接使用Model.query(). 由于这是一个异步函数,因此您必须使用asyncPromise 或重新序列化它。例如,使用 MySQL 适配器,async和一个名为 的模型User

async.auto({
  transaction: function(next){
    User.query('BEGIN', next);
  },
  user: ['transaction', function(next) {
    User.findOne(req.param('id')).exec(next);
  }],
  // other queries in the transaction
  // ...
}, function(err, results) {
  if (err) {
    User.query('ROLLBACK', next);
    return next(err);
  }
  User.query('COMMIT', next);
  // final tasks
  res.json(results.serialize);
});
于 2014-01-15T14:20:26.780 回答
6

我们正在为 ORM 级别的事务提供本地支持: https ://github.com/balderdashy/waterline/issues/62

关联可能会首先出现,但交易才是下一个。我们刚刚完成了 GROUP BY 和聚合(SUM、AVG 等)

于 2013-07-30T20:02:18.620 回答
1

SailsJS 中的事务比预期的要复杂得多。目标是让 ORM 适配器知道模型上的两个非常不同的控制器操作将通过单个 MySQL 连接发送。

执行此操作的自然方法是两个编写一个新适配器,该适配器接受附加信息以指示查询属于事务调用。这样做需要更改waterline(sails ORM 抽象模块)本身。

检查这是否有帮助 - https://www.npmjs.com/package/sails-mysql-transactions

于 2015-05-03T19:49:35.340 回答