Встроенные сущности
Эта страница переведена PageTurner AI (бета). Не одобрена официально проектом. Нашли ошибку? Сообщить о проблеме →
Существует эффективный способ уменьшить дублирование в приложении (используя композицию вместо наследования) через embedded columns.
Встроенный столбец — это столбец, который принимает класс с собственными столбцами и объедин яет их в таблицу текущей сущности базы данных.
Пример:
Предположим, у нас есть сущности User, Employee и Student.
У всех этих сущностей есть общие свойства — first name и last name.
import { Entity, PrimaryGeneratedColumn, Column } from "typeorm"
@Entity()
export class User {
@PrimaryGeneratedColumn()
id: string
@Column()
firstName: string
@Column()
lastName: string
@Column()
isActive: boolean
}
import { Entity, PrimaryGeneratedColumn, Column } from "typeorm"
@Entity()
export class Employee {
@PrimaryGeneratedColumn()
id: string
@Column()
firstName: string
@Column()
lastName: string
@Column()
salary: string
}
import { Entity, PrimaryGeneratedColumn, Column } from "typeorm"
@Entity()
export class Student {
@PrimaryGeneratedColumn()
id: string
@Column()
firstName: string
@Column()
lastName: string
@Column()
faculty: string
}
Чтобы уменьшить дублирование firstName и lastName, мы можем создать новый класс с этими столбцами:
import { Column } from "typeorm"
export class Name {
@Column()
first: string
@Column()
last: string
}
Затем вы можете "подключить" эти столбцы в своих сущностях:
import { Entity, PrimaryGeneratedColumn, Column } from "typeorm"
import { Name } from "./Name"
@Entity()
export class User {
@PrimaryGeneratedColumn()
id: string
@Column(() => Name)
name: Name
@Column()
isActive: boolean
}
import { Entity, PrimaryGeneratedColumn, Column } from "typeorm"
import { Name } from "./Name"
@Entity()
export class Employee {
@PrimaryGeneratedColumn()
id: string
@Column(() => Name)
name: Name
@Column()
salary: number
}
import { Entity, PrimaryGeneratedColumn, Column } from "typeorm"
import { Name } from "./Name"
@Entity()
export class Student {
@PrimaryGeneratedColumn()
id: string
@Column(() => Name)
name: Name
@Column()
faculty: string
}
Все столбцы, определённые в сущности Name, будут объединены в user, employee и student:
+-------------+--------------+----------------------------+
| user |
+-------------+--------------+----------------------------+
| id | int | PRIMARY KEY AUTO_INCREMENT |
| nameFirst | varchar(255) | |
| nameLast | varchar(255) | |
| isActive | boolean | |
+-------------+--------------+----------------------------+
+-------------+--------------+----------------------------+
| employee |
+-------------+--------------+----------------------------+
| id | int | PRIMARY KEY AUTO_INCREMENT |
| nameFirst | varchar(255) | |
| nameLast | varchar(255) | |
| salary | int | |
+-------------+--------------+----------------------------+
+-------------+--------------+----------------------------+
| student |
+-------------+--------------+----------------------------+
| id | int | PRIMARY KEY AUTO_INCREMENT |
| nameFirst | varchar(255) | |
| nameLast | varchar(255) | |
| faculty | varchar(255) | |
+-------------+--------------+----------------------------+
Таким образом сокращается дублирование кода в классах сущностей. Вы можете использовать любое количество столбцов (или связей) во встроенных классах. Допускается даже создание вложенных встроенных столбцов внутри вст роенных классов.