@loke/orm
v2.0.0
Published
Sequelize based ORM for MySql and Postgres
Downloads
484
Readme
@loke/orm
This package is only used in some legacy systems at LOKE, and as such is deprecated.
Dependency updates and changes will be limited to security and features to transition away from the system.
Breaking Changes
- You must now import Connection from the module.
Before: const Connection = require("@loke/orm");
After: const { Connection } = require("@loke/orm");
create
andcreateConnection
are gone. Please useConnection
.$
operators are gone, as per underlying Sequelize update. You should importOp
instead.
Before: myRepo.find({ age: {$gt: 18} })
After:
const { Op } = require("@loke/orm");
myRepo.find({ age: {[Op.gt]: 18} })
You can still use
$
operators by declaring them in the connection options using the fieldoperatorsAliases
. See sequelize documentation for more details.sequelize
,pg
andmysql2
are now peer dependencies. You must install them yourself.
Install
npm install @loke/orm
Example
const { Connection } = require('@loke/orm');
const db = new Connection('mysql://root@localhost/demo');
const petRepository = db.table('Pets', {
name: { type: String, defaultValue: () => 'Untitled' },
description: db.Text
});
const userRepository = db.table('Users', {
firstName: db.String,
lastName: db.String,
pets: [petRepository]
});
userRepository.find({firstName: 'Testing'})
.then(function (users) {
users[0].pets[0].description = 'Hello World!';
// Save changes:
return userRepository.persist(users[0]);
});
View Documentation.
Tests
npm test
Coverage
npm run coverage