Я новичок в typeorm и пытаюсь заставить эту форму работать как заклинание. У меня нет бигг ie с простыми сущностями: фотографиями и альбомами. У меня есть объединяющая таблица, чтобы узнать, какая картинка внутри какого альбома.
Итак, у меня есть следующее:
import {
Entity, PrimaryGeneratedColumn, Column, OneToMany, JoinTable,
} from 'typeorm';
import { PicturesModel } from '../pictures/pictures.model';
@Entity({
name: 'T_ALBUM_AL',
synchronize: true,
})
export class AlbumModel {
@PrimaryGeneratedColumn({
name: 'AL_id',
})
id: number;
@Column({
name: 'AL_name',
})
name: string;
@Column({
name: 'AL_created_at',
})
created_at: Date;
@Column({
name: 'AL_updated_at',
})
updated_at: Date;
@JoinTable({
name: 'TJ_PICTURE_ALBUM_PA',
joinColumn: {
name: 'PI_id',
referencedColumnName: 'PI_id',
},
})
@OneToMany(() => PicturesModel, (pictures: PicturesModel) => pictures.id)
pictures: PicturesModel[]
}
import { Entity, PrimaryGeneratedColumn, Column } from 'typeorm';
@Entity({
name: 'T_PICTURE_PI',
synchronize: true,
})
export class PicturesModel {
@PrimaryGeneratedColumn({
name: 'PI_id',
})
id: number;
@Column({
name: 'PI_name',
})
name: string;
@Column({
name: 'PI_path',
})
path: string;
@Column({
name: 'PI_created_at',
})
created_at: Date;
@Column({
name: 'PI_updated_at',
})
updated_at: Date;
@Column({
name: 'PI_size',
})
size: number;
}
Итак, у меня есть следующая модель: Обратите внимание, что пользовательский лог c пока не реализовано.
У меня очень маленький контроллер для получения альбомов, я хотел бы получить все альбомы и все фотографии внутри него:
import { Request, Response } from 'express';
import { getRepository } from 'typeorm';
import { AlbumModel } from './album.model';
class Album {
public static async getAlbums(_req: Request, res: Response): Promise<Response> {
try {
const picture = await getRepository(AlbumModel).find({ relations: ['pictures'] });
return res.json(picture);
} catch (e) {
console.error(e);
return res.json('fail');
}
}
}
export default Album;
Когда я звоню этот контроллер я получаю следующую ошибку: Однако joinColumns указана правильно
TypeError: Cannot read property 'joinColumns' of undefined
at /<something>/src/query-builder/SelectQueryBuilder.ts:1500:61
at Array.map (<anonymous>)
at SelectQueryBuilder.createJoinExpression (/<something>/src/query-builder/SelectQueryBuilder.ts:1470:57)
at SelectQueryBuilder.getQuery (/<something>/src/query-builder/SelectQueryBuilder.ts:54:21)
at SelectQueryBuilder.QueryBuilder.getQueryAndParameters (/<something>/src/query-builder/QueryBuilder.ts:415:28)
at SelectQueryBuilder.<anonymous> (/<something>/src/query-builder/SelectQueryBuilder.ts:1956:40)
at step (/<something>/node_modules/tslib/tslib.js:139:27)
at Object.next (/<something>/node_modules/tslib/tslib.js:120:57)
at /<something>/node_modules/tslib/tslib.js:113:75
Есть идеи?