Files
twenty/packages/twenty-server/src/engine/metadata-modules/index-metadata/index-field-metadata.entity.ts
Félix Malfait 1ef7b7a474 Add indices on frequent queries (#12401)
Fixes #12165

Also changed the index naming convention because some were not properly
name and would have caused conflicts in the long run
2025-06-02 09:55:45 +02:00

57 lines
1.3 KiB
TypeScript

import {
Column,
CreateDateColumn,
Entity,
Index,
JoinColumn,
ManyToOne,
PrimaryGeneratedColumn,
Relation,
UpdateDateColumn,
} from 'typeorm';
import { FieldMetadataEntity } from 'src/engine/metadata-modules/field-metadata/field-metadata.entity';
import { IndexMetadataEntity } from 'src/engine/metadata-modules/index-metadata/index-metadata.entity';
@Entity('indexFieldMetadata')
export class IndexFieldMetadataEntity {
@PrimaryGeneratedColumn('uuid')
id: string;
@Column({ nullable: false })
indexMetadataId: string;
@ManyToOne(
() => IndexMetadataEntity,
(indexMetadata) => indexMetadata.indexFieldMetadatas,
{
onDelete: 'CASCADE',
},
)
@JoinColumn()
indexMetadata: Relation<IndexMetadataEntity>;
@Column({ nullable: false })
@Index('IDX_INDEX_FIELD_METADATA_FIELD_METADATA_ID', ['fieldMetadataId'])
fieldMetadataId: string;
@ManyToOne(
() => FieldMetadataEntity,
(fieldMetadata) => fieldMetadata.indexFieldMetadatas,
{
onDelete: 'CASCADE',
},
)
@JoinColumn()
fieldMetadata: Relation<FieldMetadataEntity>;
@Column({ nullable: false })
order: number;
@CreateDateColumn({ type: 'timestamptz' })
createdAt: Date;
@UpdateDateColumn({ type: 'timestamptz' })
updatedAt: Date;
}