diff --git a/dictation_server/src/features/licenses/licenses.service.spec.ts b/dictation_server/src/features/licenses/licenses.service.spec.ts index ee7ac87..8438279 100644 --- a/dictation_server/src/features/licenses/licenses.service.spec.ts +++ b/dictation_server/src/features/licenses/licenses.service.spec.ts @@ -312,7 +312,7 @@ describe('DBテスト', () => { ); const service = module.get(LicensesService); - const issueCount = 1000; + const issueCount = 500; await service.issueCardLicenseKeys(externalId, issueCount); const dbSelectResult = await selectCardLicensesCount(source); expect(dbSelectResult.count).toEqual(issueCount); diff --git a/dictation_server/src/repositories/licenses/licenses.repository.service.ts b/dictation_server/src/repositories/licenses/licenses.repository.service.ts index 38bfcee..675aaf9 100644 --- a/dictation_server/src/repositories/licenses/licenses.repository.service.ts +++ b/dictation_server/src/repositories/licenses/licenses.repository.service.ts @@ -103,8 +103,7 @@ export class LicensesRepositoryService { const cardLicenseIssueRepo = entityManager.getRepository(CardLicenseIssue); - const licenses = []; - //TODO タスク 2409: カードライセンスのレコード作成がbulkinsertになっていない + const licenses: License[] = []; // ライセンステーブルを作成する(BULK INSERT) for (let i = 0; i < count; i++) { const license = new License(); @@ -113,7 +112,12 @@ export class LicensesRepositoryService { license.type = LICENSE_TYPE.CARD; licenses.push(license); } - const savedLicenses = await licensesRepo.save(licenses); + const savedLicenses = await licensesRepo + .createQueryBuilder() + .insert() + .into(License) + .values(licenses) + .execute(); // カードライセンス発行テーブルを作成する const cardLicenseIssue = new CardLicenseIssue(); @@ -160,17 +164,21 @@ export class LicensesRepositoryService { isDuplicateKeysExist = false; } - const cardLicenses = []; - //TODO タスク 2409: カードライセンスのレコード作成がbulkinsertになっていない + const cardLicenses: CardLicense[] = []; // カードライセンステーブルを作成する(BULK INSERT) for (let i = 0; i < count; i++) { const cardLicense = new CardLicense(); - cardLicense.license_id = savedLicenses[i].id; // Licenseテーブルの自動採番されたIDを挿入 + cardLicense.license_id = savedLicenses.generatedMaps[i].id; // Licenseテーブルの自動採番されたIDを挿入 cardLicense.issue_id = savedCardLicensesIssue.id; // CardLicenseIssueテーブルの自動採番されたIDを挿入 cardLicense.card_license_key = licenseKeys[i]; cardLicenses.push(cardLicense); } - await cardLicenseRepo.save(cardLicenses); + await cardLicenseRepo + .createQueryBuilder() + .insert() + .into(CardLicense) + .values(cardLicenses) + .execute(); }); return licenseKeys; } @@ -367,7 +375,12 @@ export class LicensesRepositoryService { }, ); // ライセンステーブルを登録(注文元) - await licenseRepo.save(newLicenses); + await licenseRepo + .createQueryBuilder() + .insert() + .into(License) + .values(newLicenses) + .execute(); // 第一階層の場合はストックライセンスの概念が存在しないため、ストックライセンス変更処理は行わない if (tier !== TIERS.TIER1) {