GitXplorerGitXplorer
k

knex-orm

public
61 stars
6 forks
11 issues

Commits

List of commits on branch master.
Unverified
d6f5e9fbc63772d0e4b9be08c832564eac6218c7

Started to work on many-to-many relations

kkripod committed 9 years ago
Unverified
b0123979da9d9509575e0e49dbe1efb656f7b396

Fixed invalid ESLint peer dependency

kkripod committed 9 years ago
Unverified
d8c185afad80983325421797c0865d80e682054e

Improved CI build process, added CI support for Node v6

kkripod committed 9 years ago
Unverified
2b8794a2b5b1091e0ca99656846e58eefefda13b

Simplified error names

kkripod committed 9 years ago
Unverified
1cf923a200d4e8e2132d8ba9666289e80c1be103

Improved error handling

kkripod committed 9 years ago
Unverified
697185b915b1f58ca4b92ca90284e3995ce61144

Fixed property name capitalization in relation.js

kkripod committed 9 years ago

README

The README file for this repository.

Knex-based object-relational mapping for JavaScript.

Version (npm) Build Status Code Coverage Gitter

Introduction

The motivation behind this project is to combine the simplicity of Bookshelf with the power of Knex and modern ECMAScript features.

Knex-ORM aims to provide a wrapper for every significant method of Knex, while keeping the ORM code overhead as low as possible.

Getting started

Installing Knex and at least one of its supported database drivers as peer dependencies is mandatory.

$ npm install knex --save
$ npm install knex-orm --save

# Then add at least one of the following:
$ npm install pg --save
$ npm install mysql --save
$ npm install mariasql --save
$ npm install sqlite3 --save

An instance of the Knex-ORM library can be created by passing a Knex client instance to the entry class.

const knex = require('knex');
const KnexOrm = require('knex-orm');

const Database = new KnexOrm(
  knex({
    client: 'sqlite3',
    connection: {
      filename: './dev.sqlite3',
    },
  })
);

class Employee extends Database.Model {
  static get tableName() { return 'employees'; } // Redundant

  // Specify related Models which can optionally be fetched
  static get related() {
    return {
      company: this.belongsTo('Company'), // No Model cross-referencing
    };
  }
}

class Company extends Database.Model {
  // The 'tableName' property is omitted on purpose, as it gets assigned
  // automatically based on the Model's class name.

  static get primaryKey() { return 'rank'; }

  static get related() {
    return {
      employees: this.hasMany('Employee'),
    };
  }
}

// Register Models to make them relatable without cross-referencing each other
Database.register(Employee);
Database.register(Company);

Examples

Creating and storing a new Model:

const famousCompany = new Company({
  name: 'A Really Famous Company',
  email: 'info@famouscompany.example'
});

famousCompany.save()
  .then((ids) => {
    // An ordinary response of a Knex 'insert' query
    // (See http://knexjs.org/#Builder-insert)
    console.log(ids);
  });

Modifying an existing Model gathered by a query:

Company.query().where({ email: 'info@famouscompany.example' }).first()
  .then((company) => {
    // Response of a Knex 'where' query, with results parsed as Models
    // (See http://knexjs.org/#Builder-where)
    console.log(company); // Should be equal with 'famousCompany' (see above)

    company.name = 'The Most Famous Company Ever';
    return company.save();
  })
  .then((rowsCount) => {
    // An ordinary response of a Knex 'update' query
    // (See http://knexjs.org/#Builder-update)
    console.log(rowsCount); // Should be 1
  });