Repository API

RepositoryAPI

  • manager - 存储库使用的EntityManager
  1. const manager = repository.manager;
  1. const metadata = repository.metadata;
  • queryRunner - EntityManager使用的查询器。仅在 EntityManager 的事务实例中使用。
  1. const queryRunner = repository.queryRunner;
  • target - 此存储库管理的目标实体类。仅在 EntityManager 的事务实例中使用。
  1. const target = repository.target;
  • createQueryBuilder - 创建用于构建 SQL 查询的查询构建器。 更多关于QueryBuilder.
  1. const users = await repository
  2. .createQueryBuilder("user")
  3. .where("user.name = :name", { name: "John" })
  4. .getMany();
  • hasId - 检查是否定义了给定实体的主列属性。
  1. if (repository.hasId(user)) {
  2. // ... do something
  3. }
  • getId - 获取给定实体的主列属性值。复合主键返回的值将是一个具有主列名称和值的对象。
  1. const userId = repository.getId(user); // userId === 1
  • create - 创建User的新实例。 接受具有用户属性的对象文字,该用户属性将写入新创建的用户对象(可选)。
  1. const user = repository.create(); // 和 const user = new User();一样
  2. const user = repository.create({
  3. id: 1,
  4. firstName: "Timber",
  5. lastName: "Saw"
  6. }); // 和const user = new User(); user.firstName = "Timber"; user.lastName = "Saw";一样
  • merge - 将多个实体合并为一个实体。
  1. const user = new User();
  2. repository.merge(user, { firstName: "Timber" }, { lastName: "Saw" }); // 和 user.firstName = "Timber"; user.lastName = "Saw";一样
  • preload - 从给定的普通 javascript 对象创建一个新实体。 如果实体已存在于数据库中,则它将加载它(以及与之相关的所有内容),并将所有值替换为给定对象中的新值,并返回新实体。 新实体实际上是从数据库加载的所有属性都替换为新对象的实体。
  1. const partialUser = {
  2. id: 1,
  3. firstName: "Rizzrak",
  4. profile: {
  5. id: 1
  6. }
  7. };
  8. const user = await repository.preload(partialUser);
  9. // user将包含partialUser中具有partialUser属性值的所有缺失数据:
  10. // { id: 1, firstName: "Rizzrak", lastName: "Saw", profile: { id: 1, ... } }
  • save - 保存给定实体或实体数组。 如果该实体已存在于数据库中,则会更新该实体。 如果数据库中不存在该实体,则会插入该实体。 它将所有给定实体保存在单个事务中(在实体的情况下,管理器不是事务性的)。 因为跳过了所有未定义的属性,还支持部分更新。
  1. await repository.save(user);
  2. await repository.save([category1, category2, category3]);
  • remove - 删除给定的实体或实体数组。
  • 它将删除单个事务中的所有给定实体(在实体的情况下,管理器不是事务性的)。
  1. await repository.remove(user);
  2. await repository.remove([category1, category2, category3]);
  • insert - 插入新实体或实体数组。
  1. await repository.insert({
  2. firstName: "Timber",
  3. lastName: "Timber"
  4. });
  5. await manager.insert(User, [
  6. {
  7. firstName: "Foo",
  8. lastName: "Bar"
  9. },
  10. {
  11. firstName: "Rizz",
  12. lastName: "Rak"
  13. }
  14. ]);
  • update - 通过给定的更新选项或实体 ID 部分更新实体。
  1. await repository.update({ firstName: "Timber" }, { firstName: "Rizzrak" });
  2. // 执行 UPDATE user SET firstName = Rizzrak WHERE firstName = Timber
  3. await repository.update(1, { firstName: "Rizzrak" });
  4. // 执行 UPDATE user SET firstName = Rizzrak WHERE id = 1
  • delete -根据实体 id, ids 或给定的条件删除实体:
  1. await repository.delete(1);
  2. await repository.delete([1, 2, 3]);
  3. await repository.delete({ firstName: "Timber" });
  • count - 符合指定条件的实体数量。对分页很有用。
  1. const count = await repository.count({ firstName: "Timber" });
  • increment - 增加符合条件的实体某些列值。
  1. await manager.increment(User, { firstName: "Timber" }, "age", 3);
  • decrement - 减少符合条件的实体某些列值。
  1. await manager.decrement(User, { firstName: "Timber" }, "age", 3);
  • find - 查找指定条件的实体。
  1. const timbers = await repository.find({ firstName: "Timber" });
  • findAndCount - 查找指定条件的实体。还会计算与给定条件匹配的所有实体数量, 但是忽略分页设置 (skiptake 选项)。
  1. const [timbers, timbersCount] = await repository.findAndCount({ firstName: "Timber" });
  • findByIds - 按 ID 查找多个实体。
  1. const users = await repository.findByIds([1, 2, 3]);
  • findOne - 查找匹配某些 ID 或查找选项的第一个实体。
  1. const user = await repository.findOne(1);
  2. const timber = await repository.findOne({ firstName: "Timber" });
  • findOneOrFail - - findOneOrFail - 查找匹配某些 ID 或查找选项的第一个实体。 如果没有匹配,则 Rejects 一个 promise。
  1. const user = await repository.findOneOrFail(1);
  2. const timber = await repository.findOneOrFail({ firstName: "Timber" });
  • query - 执行原始 SQL 查询。
  1. const rawData = await repository.query(`SELECT * FROM USERS`);
  • clear - 清除给定表中的所有数据(truncates/drops)。
  1. await repository.clear();

其他选项

SaveOptions选项可以传递save, insertupdate参数。

  • data - 使用persist方法传递的其他数据。这个数据可以在订阅者中使用。
  • listeners: boolean - 指示是否为此操作调用监听者和订阅者。默认启用,可以通过在save/remove选项中设置{listeners:false}来禁用。
  • transaction: boolean - 默认情况下,启用事务并将持久性操作中的所有查询都包裹在事务中。可以通过在持久性选项中设置{transaction:false}来禁用此行为。
  • chunk: number - 中断将执行保存到多个块组中的操作。 例如,如果要保存100.000个对象但是在保存它们时遇到问题,可以将它们分成10组10.000个对象(通过设置{chunk:10000})并分别保存每个组。 当遇到基础驱动程序参数数量限制问题时,需要此选项来执行非常大的插入。
  • reload: boolean - 用于确定是否应在持久性操作期间重新加载正在保留的实体的标志。 它仅适用于不支持RETURNING/OUTPUT语句的数据库。 默认情况下启用。

示例:

  1. // users包含用user实体数组
  2. userRepository.insert(users, {chunk: users.length / 1000});

RemoveOptions可以传递removedelete参数。

  • data - 使用remove方法传递的其他数据。 这个数据可以在订阅者中使用。
  • listener: boolean - 指示是否为此操作调用监听者和订阅者。默认启用,可以通过在save/remove选项中设置{listeners:false}来禁用。
  • transaction: boolean - 默认情况下,启用事务并将持久性操作中的所有查询都包裹在事务中。可以通过在持久性选项中设置{transaction:false}来禁用此行为。
  • chunk: number - 中断将执行保存到多个块组中的操作。 例如,如果要保存100.000个对象但是在保存它们时遇到问题,可以将它们分成10组10.000个对象(通过设置{chunk:10000})并分别保存每个组。 当遇到基础驱动程序参数数量限制问题时,需要此选项来执行非常大的插入。

示例:

  1. // users包含用user实体数组
  2. userRepository.remove(users, {chunk: entities.length / 1000});

TreeRepositoryAPI

对于 TreeRepository API 请参考 Tree Entities 文档.

MongoRepositoryAPI

对于 MongoRepository API 请参考 MongoDB 文档.