An ORM to be used inside and outside StackerJS
Entities must be configured:
// Entities/User.js
export class User
{
metadata()
{
return {
'table': 'users',
'fields': [
{ 'name': 'id', 'type': 'pk' },
{ 'name': 'name', 'type': 'string', 'required': true },
{ 'name': 'active', 'type': 'boolean', 'default': true }
],
'relations': []
}
}
}
And then Repository is declared:
// Repositories/UserRepository.js
import { User } from './../Entities/User';
export class UserRepository
{
constructor()
{
this.entity = new User();
}
}
let user = new User();
user['name'] = 'My Name is...';
let usersRepository = new UserRepository();
usersRepository.save(user)
.then(response => {
if (!response)
console.log(usersRepository.getErrors());
return response;
});
let usersRepository = new UserRepository();
// Fetching by ID
let user = await usersRepository.findById(1);
// Fetching one by filter as string
let user = await usersRepository.findOne("active = 1");
//Fetching many by filter as object
let user = await usersRepository.findAll({
'active': { 'eq': true } // or 'active': [ 'eq', true ]
});
Term | MySQL Term | Description |
---|---|---|
eq | = | Looks for exactly equal results |
neq | <> | Looks for exactly different |
gt | > | Looks for greater values |
gte | >= | Looks for greater or equal values |
lt | < | Looks for lower values |
lte | <= | Looks for lower or equal values |
in | IN | Looks for values inside array |
nin | NOT INT | Looks for values not inside array |