To use mikro-orm
with Vanilla JavaScript, define your entities like this:
const { Collection } = require('mikro-orm');
const { Book } = require('./Book');
const { BaseEntity } = require('./BaseEntity');
/**
* @property {number} id
* @property {Date} createdAt
* @property {Date} updatedAt
* @property {string} name
* @property {string} email
* @property {number} age
* @property {boolean} termsAccepted
* @property {string[]} identities
* @property {Date} born
* @property {Collection<Book>} books
* @property {Book} favouriteBook
* @property {number} version
* @property {string} versionAsString
*/
class Author extends BaseEntity {
/**
* @param {string} name
* @param {string} email
*/
constructor(name, email) {
super();
this.name = name;
this.email = email;
this.createdAt = new Date();
this.updatedAt = new Date();
this.termsAccepted = false;
}
}
const schema = {
name: 'Author',
extends: 'BaseEntity',
properties: {
createdAt: 'Date',
updatedAt: {
type: 'Date',
onUpdate: () => new Date(),
},
name: 'string',
email: 'string',
age: 'number',
termsAccepted: 'boolean',
identities: 'string[]',
born: 'Date',
books: {
reference: '1:m',
mappedBy: 'author',
type: 'Book',
},
favouriteBook: {
reference: 'm:1',
type: 'Book',
},
},
path: __filename,
};
module.exports.Author = Author;
module.exports.entity = Author;
module.exports.schema = schema;
Do not forget to provide
name
andpath
schema parameters as well asentity
andschema
exports.
Reference parameter can be one of (where SCALAR
is the default one):
export enum ReferenceType {
SCALAR = 'scalar',
MANY_TO_ONE = 'm:1',
ONE_TO_MANY = '1:m',
MANY_TO_MANY = 'm:n',
}
When initializing ORM, provide JavaScriptMetadataProvider
as metadata provider:
const orm = await MikroORM.init({
entitiesDirs: ['entities'],
dbName: '...',
metadataProvider: JavaScriptMetadataProvider,
});
For more examples of plain JavaScript entity definitions take a look at the tests or at Express JavaScript example.