Как создать данные отношений с TypeORM? - PullRequest
0 голосов
/ 20 июня 2019

Я пытаюсь создать и сохранить продукты пользователя.

Вот моя попытка:

// userEntity.ts

import { Product } from '../product';

@Entity('user')
export class User {
  @PrimaryGeneratedColumn()
  id: number;

  @Column({
    unique: true
  })
  email: string;

  @Column()
  password: string;

  @OneToMany(type => Product, product => product.user)
  @JoinTable()
  products: Product[];

  @CreateDateColumn()
  createdAt: Date;

  @UpdateDateColumn()
  updatedAt: Date;
}
// productEntity.ts

import { ProductCategory } from './productCategoryEntity';
import { User } from '../user';

@Entity('product')
export class Product {
  @PrimaryGeneratedColumn()
  id: number;

  @Column()
  name: string;

  @ManyToOne(type => ProductCategory, {
    eager: true,
    cascade: true
  })
  @JoinTable()
  category: ProductCategory;

  @ManyToOne(type => User, user => user.products)
  @JoinTable()
  user: User;

  @CreateDateColumn()
  createdAt: Date;

  @UpdateDateColumn()
  updatedAt: Date;
}

POST при http://localhost:4000/users/1/products. Это успешно создает продукт, но не относится к пользователю.

// userPost.ts

export async function userPostProduct(
  req: Request,
  res: Response,
  next: NextFunction
): Promise<void> {
  try {
    const userRepository: Repository<User> = getManager().getRepository(User);
    const productRepository: Repository<Product> = getManager().getRepository(
      Product
    );

    // Load user by id
    const user = await userRepository.findOne(req.params.id);

    const { ...data } = req.body;

    const productToBeSaved = new Product();
    productToBeSaved.name = data.name;
    productToBeSaved.shortDescription = data.shortDescription;
    productToBeSaved.longDescription = data.longDescription;
    productToBeSaved.price = data.price;
    productToBeSaved.category = data.category;
    if (user) {
      productToBeSaved.user = user;
    }

    // Validate product entity
    const errors: ValidationError[] = await validate(productToBeSaved, {
      skipMissingProperties: true
    }); // Errors is and array of validation errors

    if (errors.length > 0) {
      // Return BAD REQUEST status code
      return next(createError(400, errors));
    } else {
      let product = await productRepository.save(productToBeSaved);
      // Return a CREATED status code and new product
      res.status(201).send({
        message: 'Product saved successfully',
        product
      });
    }
  } catch (err) {
    // Return a BAD REQUEST status code and email already exists error
    return next(createError(400, err));
  }
}

Я не могу запросить продукцию пользователя 1 в GET http://localhost:4000/users/1/products

Я тоже пробовал это:

// Build up entity product to be saved
const productToBeSaved = productRepository.create(req.body);
productToBeSaved.user = user;

if (user) {
  user.products = [productToBeSaved];
  await userRepository.save(user);
}

.. но там сказано productToBeSaved missing properties of Product[]: id, name, category, etc...

Итак, я изменил:

if (user) {
  user.products = [...productToBeSaved];
  await userRepository.save(user);
}

Тогда он сказал TypeError: productToBeSaved is not iterable

Пожалуйста, помогите мне, как мне создать продуктовые отношения пользователя.

Технический стек: TypeScript, Express, PostgreSQL, TypeORM


Я действительно хочу использовать TypeORM, хотелось бы, чтобы у них были лучшие примеры.

...