我正在重写一个使用Node.js的项目。我想继续使用MySQL作为数据库(即使我不介意重写模式)。 我正在寻找一种易于使用、性能合理的ORM,它支持缓存、多对一和多对多关系。 从我能找到的MySQL orm来看,persistencejs和sequelize似乎是最成熟的。 你有这两方面的经验吗?在做决定时,我应该注意哪些相关的利弊?
当前回答
首先,请注意,我没有使用过它们(但使用过Node.js)。
这两个库都有很好的文档记录,并有一个 稳定的API。然而,persistence.js似乎在更多的项目中使用。不过,我不知道他们是否还在使用它。
续作的开发者有时会在blog.depold.com上发表博文。当你想使用主键作为外键时,你需要这篇博文中描述的补丁。如果你想要一些关于persistence.js的帮助,有一个谷歌小组致力于此。
从我收集的例子来看,sequelize比persistence .js更像javascript(更糖),但支持的数据存储更少(只支持MySQL,而persistence .js甚至可以使用浏览器内存储)。
我认为续集可能是你的方式,因为你只需要MySQL的支持。然而,如果你需要一些方便的功能(例如搜索),或者以后想要使用不同的数据库,你就需要使用persistence.js。
其他回答
Sequelize和Persistence.js之间的一个主要区别是前者支持STRING数据类型,即VARCHAR(255)。我觉得把所有东西都变成文本真的很不舒服。
首先,请注意,我没有使用过它们(但使用过Node.js)。
这两个库都有很好的文档记录,并有一个 稳定的API。然而,persistence.js似乎在更多的项目中使用。不过,我不知道他们是否还在使用它。
续作的开发者有时会在blog.depold.com上发表博文。当你想使用主键作为外键时,你需要这篇博文中描述的补丁。如果你想要一些关于persistence.js的帮助,有一个谷歌小组致力于此。
从我收集的例子来看,sequelize比persistence .js更像javascript(更糖),但支持的数据存储更少(只支持MySQL,而persistence .js甚至可以使用浏览器内存储)。
我认为续集可能是你的方式,因为你只需要MySQL的支持。然而,如果你需要一些方便的功能(例如搜索),或者以后想要使用不同的数据库,你就需要使用persistence.js。
我会选择Sequelize,因为它有出色的文档。这只是一个诚实的意见(我从来没有真正使用MySQL与Node)。
我可以推荐Node ORM吗?
https://github.com/dresende/node-orm2
Readme上有文档,支持MySQL, PostgreSQL和SQLite。
MongoDB从2.1版本开始可用。x(2013年7月发布)
更新:根据项目的README,这个包不再维护。相反,它推荐书架和续集
推荐文章
- 我可以从一个完整的mysql mysqldump文件恢复一个表吗?
- 在用nodejs和express创建的REST API中设置响应状态和JSON内容的正确方法
- 如何获得请求路径与表达请求对象
- 计数在VARCHAR字段中字符串的出现次数?
- 节点和错误:EMFILE,打开的文件太多
- 修改一个MySQL列为AUTO_INCREMENT
- 在ROR迁移期间,将列类型从Date更改为DateTime
- 没有定义Electron require()
- 在摩卡测试时调用异步函数如何避免超时错误:超时超过2000ms
- 如何删除所有MySQL表从命令行没有DROP数据库权限?
- package.json中属性“private”的目的是什么?
- 是否有一种使用Dapper调用存储过程的方法?
- 用套接字发送消息到指定客户端。IO和node.js
- 当我运行' npm install '时,它返回' ERR!代码EINTEGRITY ' (npm 5.3.0)
- 从主机连接到docker容器中的mysql