orm 不等于_您可能不知道的3个JavaScript ORM

orm 不等于

当我编写第一行JavaScript代码时,我从没想到它会超越浏览器脚本和制作交互式网站。 我错了,因为JavaScript实际上可以在任何地方使用:

  • 您可以在浏览器中使用它,而不必限于使用带有DOM API的ECMAscript。 诸如CoffeeScriptDart之类的语言可以转换为普通的旧JavaScript,可以帮助您开发更快更好的代码。
  • 您可以在服务器上使用它。 Node.js及其众多框架的数量正在增加,并帮助前端开发人员成为全栈开发人员。
  • 您可以将其用于移动应用程序。 使用CordovaIonicNativeScript之类的框架,您可以更快地构建移动应用程序,而无需了解其他语言,例如Java或Swift / Objective-C。 由于有了这些框架,您甚至可以在移动平台之间共享源代码。
  • 您可以构建物联网。 SitePoint已发表了Patrick Catanzariti的一些文章 ,可能对此很有帮助。

随着您所开发应用程序的复杂性的提高,您将需要一些帮助您处理存储在数据库中的所有数据的方法,无论是在DB服务器(如PostgreSQL),移动设备的嵌入式SQLite中,或在浏览器中。 这就需要ORM。 Java社区具有Hibernate ,PHP开发人员可以使用Doctrine ORM ,而JavaScript社区具有自己的ORM。

在本文中,我将向您介绍一些JavaScript ORM,它们可以帮助您在下一个应用程序中处理复杂数据。

Bookshelf.js

Bookshelf.js是Node.js的ORM,旨在与PostgreSQL,MySQL,MariaDB和SQLite3配合使用。 它基于Knex SQL查询构建器构建,并遵循Backbone.js中看到的一些模式,例如模型和集合以及类似的命名约定。 如果您曾经使用过Backbone,则可能会很快适应书架。

要安装Bookshelf,您需要安装Knex以及一个DataBase驱动程序:

# get knex
$ npm install knex --save

# get bookshelf
$ npm install bookshelf --save

# get one of these DB drivers
$ npm install pg
$ npm install mysql
$ npm install mariasql
$ npm install sqlite3

安装后(确保传递--save标志,以便将其添加到package.json文件中),您可以像下面这样在Node.js应用程序中使用它:

var knexInstance = require('knex')({
  client: 'mysql', // or what DB you're using
  connection: {
    host     : '127.0.0.1',
    user     : 'scott',
    password : 'tiger', // Scott's cat name
    database : 'db_name',
    charset  : 'utf8'
  }
});
// Initialize Bookshelf by passing the Knex instance
var bookshelf = require('bookshelf')(knexInstance); 

var User = bookshelf.Model.extend({
  tableName: 'users'
});

如您所见,通过传递Knex实例作为参数来创建书架对象。 然后,可以使用Modelextend()方法在应用程序中创建模型,就像上面示例中用于表usersUser模型一样。 请记住, bookshelf是您应在整个应用程序中使用的唯一书架实例。 因此,最好在应用程序中的任何位置都可以访问它,例如将其包装为单例或放入其他文件中,并在需要时进行使用。

书架允许您建立一对一,一对多和多对多的关系。 在我们的情况下,它将类似于:

var User = bookshelf.Model.extend({
  tableName: 'users',
  posts: function() {
    return this.hasMany(Post);
  }
});

var Post = bookshelf.Model.extend({
  tableName: 'posts',
  user: function() {
    return this.belongsTo(User);
  }
});

如果您想看看它, 可以在GitHub上找到Bookshelf

续集

Sequelize是Node.js和io.js( 最终合并在一起 )的另一个ORM。 它支持PostgreSQL,MySQL,MariaDB,SQLite和MSSQL,并具有可靠的事务支持,关系,读取复制和
更多。 您可以通过运行以下命令来安装它:

# Install Sequelize
$ npm install --save sequelize

# Install the DB driver
$ npm install --save pg pg-hstore

# For both mysql and mariadb dialects
$ npm install --save mysql 
$ npm install --save sqlite3

# MSSQL
$ npm install --save tedious

现在您可以使用它了,如下面的示例所示:

var Sequelize = require('sequelize');
var sequelize = new Sequelize('database', 'username', 'password', {
  host: 'localhost',
  dialect: 'mysql'|'mariadb'|'sqlite'|'postgres'|'mssql', // use one of these

  pool: {
    max: 5,
    min: 0,
    idle: 10000
  },

  // SQLite only
  storage: 'path/to/database.sqlite'
});

// Or you can simply use a connection uri
var sequelize = new Sequelize('postgres://user:pass@example.com:5432/dbname');

就像Bookshelf.js一样,您只需要一个数据库连接即可。 之后,您可以创建一个模型,例如:

var User = sequelize.define('user', {
  firstName: {
    type: Sequelize.STRING,
    field: 'first_name' // `first_name` column matches User.firstName
  },
  lastName: {
    type: Sequelize.STRING
  }
}, {
  freezeTableName: true // Model tableName (`user`) will be the same as the model name
});

上面的Sequelize.STRING与SQL中的VARCHAR匹配。 其他数据类型是Sequelize.INTEGERINTEGERSequelize.BLOBBLOB (或bytea Postgres里)。 您可以在此处阅读完整列表

Sequelize允许您编写表之间的关系 。 例如,如果您有一个名为Project的模型,又有一个称为Developer的模型,并且想要为一个项目分配多个开发者,则可以这样进行:

Project.hasMany(Developer, {as: 'devs'})

这将确保在每个模型中添加必要的字段(在这种情况下,将project_id到Developer模型)。 或者,如果您觉得无法从Sequelize API中获利,则可以运行原始SQL查询

Sequelize也可以在GitHub上找到

爱情

Lovefield不是真正的ORM。 它实际上是Web应用程序的关系数据库,建立在IndexedDB的基础上,由Google开发并完全用JavaScript编写。 它不支持原始SQL查询,但带有一个试图模仿SQL语法的API。

您可以使用Bower安装它:

$ bower install lovefield --save

npm

$ npm install lovefield --save

免费学习PHP!

全面介绍PHP和MySQL,从而实现服务器端编程的飞跃。

原价$ 11.95 您的完全免费

在将其添加到HTML文件中之后,您可以开始将其用作前端关系数据库。 创建数据库和表很简单:

// create the database for a `To Do list`
var todoDB = lf.schema.create('todo_db', 1);

var item = todoDB.createTable('items')
      .addColumn('id', lf.Type.INTEGER)
      .addColumn('task', lf.Type.STRING)
      .addColumn('deadline', lf.Type.DATE_TIME)
      .addColumn('done', lf.Type.BOOLEAN)
      .addPrimaryKey(['id']);

此代码段显示了如何创建具有给定列( id为主键, taskdeadlinedone )的数据库todo_db和一个名为items的表。 此时,要获得所有未完成任务的列表,代码将是:

todoDB.select()
  .from(item)
  .where(item.done.eq(false))
  .exec(); // exec() returns a Promise

上面的代码与SQL非常相似,其中相同的查询为:

SELECT * 
    FROM todo_db.items 
    WHERE done = FALSE;

您也可以像这样订购:

todoDB.select()
  .from(item)
  .where(item.done.eq(false))
  .orderBy(item.deadline, lf.Order.DESC) // order by deadline
  .exec();

除了这些简单的查询外,Lovefield还能够处理更复杂的查询,例如联接。 如果我在称为projectdeveloper两个表中有引用(分别引用表的projectsdevelopers ),并且想要查看给定开发者的所有项目,我会写:

db.select()
  .from(developer, project)
  .where(lf.op.and(
    developer.projectId.eq(project.id),
    developer.id.eq('12345')
  ))
  .exec();

// these are both equivalent
db.select()
  .from(developer)
  .innerJoin(project, developer.projectId.eq(project.id))
  .where(developer.id.eq('12345'))
  .exec();

因此,您可以看到Lovefield充当IndexedDB之上SQL层。 它还支持ACID事务(原子性,一致性,隔离性,持久性),限制和跳过(在分页时很有用),参数化查询等等。

就像其他ORM一样,您可以从GitHub下载 Lovefield。

结论

SQL知识是每个开发人员都应该具备的技能,但是编写SQL查询很无聊,尤其是在有那么多ORM的情况下。 当它们简化您的工作时,为什么不首先使用它们呢? 在本文中,我介绍了到目前为止发布的一些最重要的ORM。 由于为每个示例提供了示例,您现在应该能够有意识地决定使用哪种示例以及哪种版本适合您的需求。

你呢? 您使用哪个JavaScript ORM? 在下面评论您的选择。

翻译自: https://www.sitepoint.com/3-javascript-orms-you-might-not-know/

orm 不等于

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值