@loopback/docs
Version:
Documentation for LoopBack 4
59 lines (41 loc) • 1.86 kB
Markdown
lang: en
title: 'API docs: repository.defaultcrudrepository.createhasmanyrepositoryfactoryfor'
keywords: LoopBack 4.0, LoopBack 4
sidebar: lb4_sidebar
permalink: /doc/en/lb4/apidocs.repository.defaultcrudrepository.createhasmanyrepositoryfactoryfor.html
<!-- Do not edit this file. It is automatically generated by API Documenter. -->
[Home](./index.md) > [@loopback/repository](./repository.md) > [DefaultCrudRepository](./repository.defaultcrudrepository.md) > [createHasManyRepositoryFactoryFor](./repository.defaultcrudrepository.createhasmanyrepositoryfactoryfor.md)
## DefaultCrudRepository.createHasManyRepositoryFactoryFor() method
Function to create a constrained relation repository factory
<b>Signature:</b>
```typescript
protected createHasManyRepositoryFactoryFor<Target extends Entity, TargetID, ForeignKeyType>(relationName: string, targetRepoGetter: Getter<EntityCrudRepository<Target, TargetID>>): HasManyRepositoryFactory<Target, ForeignKeyType>;
```
## Parameters
| Parameter | Type | Description |
| --- | --- | --- |
| relationName | <code>string</code> | Name of the relation defined on the source model |
| targetRepoGetter | <code>Getter<EntityCrudRepository<Target, TargetID>></code> | |
<b>Returns:</b>
`HasManyRepositoryFactory<Target, ForeignKeyType>`
## Example
```ts
class CustomerRepository extends DefaultCrudRepository<
Customer,
typeof Customer.prototype.id
> {
public readonly orders: HasManyRepositoryFactory<Order, typeof Customer.prototype.id>;
constructor(
protected db: juggler.DataSource,
orderRepository: EntityCrudRepository<Order, typeof Order.prototype.id>,
) {
super(Customer, db);
this.orders = this._createHasManyRepositoryFactoryFor(
'orders',
orderRepository,
);
}
}
```