2024-05-20 20:31:36 -04:00
|
|
|
import { getVectorExtension } from 'src/database.config';
|
2024-03-21 12:59:49 +01:00
|
|
|
import { DatabaseExtension } from 'src/interfaces/database.interface';
|
2023-12-08 11:15:46 -05:00
|
|
|
import { MigrationInterface, QueryRunner } from 'typeorm';
|
|
|
|
|
|
|
|
|
|
export class AddFaceEmbeddingIndex1700714033632 implements MigrationInterface {
|
|
|
|
|
name = 'AddFaceEmbeddingIndex1700714033632';
|
|
|
|
|
|
|
|
|
|
public async up(queryRunner: QueryRunner): Promise<void> {
|
2024-05-20 20:31:36 -04:00
|
|
|
if (getVectorExtension() === DatabaseExtension.VECTORS) {
|
2024-02-06 21:46:38 -05:00
|
|
|
await queryRunner.query(`SET vectors.pgvector_compatibility=on`);
|
|
|
|
|
}
|
|
|
|
|
await queryRunner.query(`SET search_path TO "$user", public, vectors`);
|
|
|
|
|
|
2023-12-08 11:15:46 -05:00
|
|
|
await queryRunner.query(`
|
|
|
|
|
CREATE INDEX IF NOT EXISTS face_index ON asset_faces
|
2024-02-06 21:46:38 -05:00
|
|
|
USING hnsw (embedding vector_cosine_ops)
|
|
|
|
|
WITH (ef_construction = 300, m = 16)`);
|
2023-12-08 11:15:46 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public async down(queryRunner: QueryRunner): Promise<void> {
|
|
|
|
|
await queryRunner.query(`DROP INDEX IF EXISTS face_index`);
|
|
|
|
|
}
|
|
|
|
|
}
|