Page Contents
Home > @loopback/sequelize > SequelizeCrudRepository
SequelizeCrudRepository class
Sequelize implementation of CRUD repository to be used with default loopback entities and SequelizeDataSource for SQL Databases
Signature:
export declare class SequelizeCrudRepository<T extends Entity, ID, Relations extends object = {}> implements EntityCrudRepository<T, ID, Relations>
Implements: EntityCrudRepository<T, ID, Relations>
Constructors
| Constructor | Modifiers | Description |
|---|---|---|
| [(constructor)(entityClass, dataSource)](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository._constructor_.html) | Constructs a new instance of the `SequelizeCrudRepository` class |
Properties
| Property | Modifiers | Type | Description |
|---|---|---|---|
| [dataSource](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.datasource.html) | [SequelizeDataSource](/doc/en/lb4/apidocs.sequelize.sequelizedatasource.html) | ||
| [DB\_SPECIFIC\_SETTINGS\_KEYS](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.db_specific_settings_keys.html) | `readonly` | readonly \["postgresql", "mysql", "sqlite3"\] | Object keys used in models for set database specific settings. Example: In model property definition one can use postgresql dataType as float `{ type: 'number', postgresql: { dataType: 'float', precision: 20, scale: 4, }, }` This array of keys is used while building model definition for sequelize. |
| [DEFAULT\_ORDER\_STYLE](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.default_order_style.html) | `readonly` | (not declared) | Default `order` filter style if only column name is specified |
| [defaultFnRegistry](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.defaultfnregistry.html) | `protected` | Record<string, unknown> | The alias registry for `defaultFn` option used in model property definition. See: https://loopback.io/doc/en/lb4/Model.html\#property-decorator |
| [entityClass](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.entityclass.html) | typeof Entity & { prototype: T; } | ||
| [inclusionResolvers](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.inclusionresolvers.html) | `readonly` | Map<string, InclusionResolver<T, Entity>> | |
| [NANO\_ID\_LENGTH](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.nano_id_length.html) | number | Length of the `nanoid` generated for defaultFn's `shortid` and `nanoid` aliases. | |
| [sequelizeModel](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.sequelizemodel.html) | ModelStatic<Model<T>> | Sequelize Model Instance created from the model definition received from the `entityClass` |
Methods
| Method | Modifiers | Description |
|---|---|---|
| [beginTransaction(options)](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.begintransaction.html) | ||
| [buildSequelizeAttributeFilter(fields)](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.buildsequelizeattributefilter.html) | `protected` | Get Sequelize `attributes` filter value from `fields` of loopback. |
| [buildSequelizeIncludeFilter(inclusionFilters, sourceModel)](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.buildsequelizeincludefilter.html) | `protected` | Build Sequelize compatible `include` filter |
| [buildSequelizeOrder(order)](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.buildsequelizeorder.html) | `protected` | Get Sequelize Order filter value from loopback style order value. It also supports passing associations in the order array to sort by nested models. Example: `["user email ASC"]`. |
| [buildSequelizeWhere(where)](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.buildsequelizewhere.html) | `protected` | Build Sequelize compatible where condition object |
| [count(where, options)](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.count.html) | ||
| [create(entity, options)](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.create.html) | ||
| [createAll(entities, options)](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.createall.html) | ||
| [createBelongsToAccessorFor(relationName, targetRepositoryGetter)](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.createbelongstoaccessorfor.html) | `protected` | Function to create a belongs to accessor |
| [createHasManyRepositoryFactoryFor(relationName, targetRepositoryGetter)](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.createhasmanyrepositoryfactoryfor.html) | `protected` | Function to create a constrained relation repository factory |
| [createHasManyThroughRepositoryFactoryFor(relationName, targetRepositoryGetter, throughRepositoryGetter)](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.createhasmanythroughrepositoryfactoryfor.html) | `protected` | Function to create a constrained hasManyThrough relation repository factory |
| [createHasOneRepositoryFactoryFor(relationName, targetRepositoryGetter)](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.createhasonerepositoryfactoryfor.html) | `protected` | Function to create a constrained hasOne relation repository factory |
| [createReferencesManyAccessorFor(relationName, targetRepoGetter)](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.createreferencesmanyaccessorfor.html) | `protected` | Function to create a references many accessor |
| [delete(entity, options)](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.delete.html) | ||
| [deleteAll(where, options)](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.deleteall.html) | ||
| [deleteById(id, options)](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.deletebyid.html) | ||
| [excludeHiddenProps(entity)](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.excludehiddenprops.html) | `protected` | Remove hidden properties specified in model from response body. (See: https://github.com/sourcefuse/loopback4-sequelize/issues/3) |
| [execute(command, parameters, options)](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.execute.html) | Execute a SQL command. \*\*WARNING:\*\* In general, it is always better to perform database actions through repository methods. Directly executing SQL may lead to unexpected results, corrupted data, security vulnerabilities and other issues. | |
| [exists(id, \_options)](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.exists.html) | ||
| [find(filter, options)](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.find.html) | ||
| [findById(id, filter, options)](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.findbyid.html) | ||
| [findOne(filter, options)](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.findone.html) | ||
| [getDefaultFnRegistry()](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.getdefaultfnregistry.html) | `protected` | |
| [getSequelizeModel(entityClass)](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.getsequelizemodel.html) | Get Sequelize Model | |
| [getSequelizeModelAttributes(definition)](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.getsequelizemodelattributes.html) | `protected` | Get Sequelize Model Attributes |
| [getSequelizeOperator(key)](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.getsequelizeoperator.html) | `protected` | Get Sequelize Operator |
| [getTableName(entityClass)](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.gettablename.html) | This function retrieves the table name associated with a given entity class. Different loopback connectors have different conventions for picking up table names, unless the name is specified in the decorator. The function follows the following cases to determine the table name: - It checks if the name property is specified in the decorator and uses it. (this takes precedence over all other cases) - If the dialect of the dataSource is PostgreSQL, it uses the lowercased version of the model class name. - If the dialect is MySQL or any other dialect, it uses the default model class name. | |
| [includeReferencesIfRequested(parentEntities, parentEntityClass, inclusionFilters)](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.includereferencesifrequested.html) | `protected` | Include related entities of `@referencesMany` relation referencesMany relation is NOT handled by `sequelizeModel.findAll` as it doesn't have any direct alternative to it, so to include relation data of referencesMany, we're manually fetching related data requested |
| [isInclusionAllowed(include)](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.isinclusionallowed.html) | `protected` | Checks if the resolver of the inclusion relation is registered in the inclusionResolver of the current repository |
| [registerInclusionResolver(relationName, resolver)](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.registerinclusionresolver.html) | Register an inclusion resolver for the related model name. | |
| [replaceById(id, data, options)](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.replacebyid.html) | ||
| [save(entity, options)](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.save.html) | ||
| [syncLoadedSequelizeModels(options)](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.syncloadedsequelizemodels.html) | Run CREATE TABLE query for the all sequelize models, Useful for quick testing | |
| [syncSequelizeModel(options)](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.syncsequelizemodel.html) | Run CREATE TABLE query for the target sequelize model, Useful for quick testing | |
| [toEntities(models)](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.toentities.html) | `protected` | |
| [update(entity, options)](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.update.html) | ||
| [updateAll(data, where, options)](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.updateall.html) | ||
| [updateById(id, data, options)](/doc/en/lb4/apidocs.sequelize.sequelizecrudrepository.updatebyid.html) |