[英]How to initialize an entity passing in an object using typeorm
我有一个实体“列表”,我想通过将 object 传入构造函数来创建一个新列表。
列表.ts
import {Entity, PrimaryColumn, Column, CreateDateColumn, UpdateDateColumn, DeleteDateColumn } from "typeorm";
@Entity()
export class List {
@PrimaryColumn()
id: string;
@Column({type: "varchar", nullable: true})
dtype: string;
@Column({type: "varchar", nullable: true})
title: string;
@Column({type: "varchar"})
user_id: string;
@Column({type: "varchar", nullable: true})
brand_id: string;
@CreateDateColumn({type: "timestamp", nullable: true})
created_at: string;
@UpdateDateColumn({type: "timestamp", nullable: true})
updated_at: string;
@DeleteDateColumn({type: "timestamp", nullable: true})
deleted_at: string;
}
列表测试
import "reflect-metadata";
import {createConnection, getRepository} from "typeorm";
import {List} from "./../../src/entity/lists/List";
describe("List", () => {
let connection
beforeAll( async () => {
connection = await createConnection();
console.log(connection);
});
it("should insert a list into database", async () => {
const listRepository = getRepository(List);
const list = new List({
id: "7e60c4ef",
dtype: "brandlist",
title: "OnePlus",
user_id: "3aecd1b0-c34d-4427-9abd-fdacef00eaa5",
brand_id: "7e60c4ef-0e6f-46c9-948b-a97d555bf4e4",
});
})
})
现在我得到以下
预期为 0 arguments,但得到 1.ts(2554)
有没有办法 typeorm 可以自动处理这个?
有两种方法可以解决这个问题,第一种是在列表 class 中声明自己的构造函数并分配值,但它会变得混乱。
首选方法是使用repository.create
从 object 创建实体实例。 https://github.com/typeorm/typeorm/blob/master/docs/repository-api.md
const listRepository = connection.getRepository(List);
const list = listRepository.create({
id: "7e60c4ef",
dtype: "brandlist",
title: "OnePlus",
user_id: "3aecd1b0-c34d-4427-9abd-fdacef00eaa5",
brand_id: "7e60c4ef-0e6f-46c9-948b-a97d555bf4e4",
});
const newList = await listRepository.save(list);
编辑:我确实通过尝试搜索如何通过传递属性/主体参数/对象来初始化 TypeORM 对象/类来到达这个线程。 因此,如果您需要单个 object,您可以使用管理器。
import { getManager } from "typeorm";
// ...
const manager = getManager();
const newUser = manager.create(User, req.body);
const user = await manager.save(newUser);
创建用户 object 并将其从快速请求动态主体中保存的示例。 这个例子只是为了说明。 在将架构传递给创建 function 之前验证和清理架构,以避免允许 API 用户传递任何参数,例如{admin: true}
;)。
import { getManager } from "typeorm";
createConnection()
.then(async (connection) => {
const app = express();
app.use(express.json());
app.post("/users", async (req: Request, res: Response) => {
const manager = getManager();
const newUser = manager.create(User, req.body);
const user = await manager.save(newUser);
res.json(user);
});
app.listen(4000);
})
.catch((error) => console.log(error));
我只想添加到@Kay 的答案。 如果您通过从 typeorm 扩展BaseEntity class 来使用Active Records模式,则可以直接在实体上调用 create 方法,假设 List 是实体,例如
const newList = List.create({
id: "7e60c4ef",
dtype: "brandlist",
title: "OnePlus",
user_id: "3aecd1b0-c34d-4427-9abd-fdacef00eaa5",
brand_id: "7e60c4ef-0e6f-46c9-948b-a97d555bf4e4",
})
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.