중첩된 일괄 삽입의 한 가지 과제는 삽입 순서입니다. 부모와 자식 테이블 사이에 외래 키 참조를 사용하여 테이블을 생성한다고 가정해 보겠습니다. 일반적으로 하위 레코드를 삽입하려면 상위 레코드가 있어야 합니다. 이 문제를 처리하려면 상위 레코드를 먼저 삽입한 다음 하위 레코드를 삽입해야 합니다.
문제는 상위 레코드 ID를 사용할 수 있을 때까지 하위 레코드를 삽입할 수 없다는 것입니다. 이 문제를 극복하는 한 가지 방법은 저장 프로시저를 사용하여 레코드를 삽입하는 것입니다. 저장 프로시저는 상위 레코드를 먼저 삽입한 다음 하위 레코드를 삽입할 수 있습니다. 이 접근 방식을 사용하면 상위 레코드가 하위 레코드 앞에 삽입되고 각 하위 레코드에 유효한 상위 ID가 있는지 확인됩니다.
중첩된 대량 삽입을 수행하는 또 다른 방법은 '테이블 스테이징'이라는 기술을 사용하는 것입니다. 테이블 준비에는 하위 레코드를 저장하기 위한 임시 테이블을 만드는 작업이 포함됩니다. 상위 레코드가 먼저 삽입된 다음 하위 레코드가 임시 테이블에 삽입됩니다. 모든 하위 레코드가 삽입되면 병합 문을 사용하여 하위 레코드를 실제 하위 테이블에 삽입할 수 있습니다. 이 접근 방식의 장점은 하위 레코드를 삽입하기 전에 상위 테이블과 비교하여 검사하므로 하위 레코드가 유효한지 확인한다는 것입니다.
마지막으로 insert 문의 OUTPUT 절을 사용하여 기본 키(예:scope_identity())를 캡처하고 사용할 수 있습니다. 이렇게 하면 하위 엔터티를 반복할 수 있습니다. 다음은 이 접근 방식의 예입니다.
<code> using (var scope = tran.Connection.BeginTransaction()) { using (connectionString.WithTransaction(tran)) { int scope_identity = 0; foreach (var entity in dataload.Entities){ scope_identity = connectionString.ExecuteScalar<int>( $"INSERT INTO tbl_owner(OwnerName) OUTPUT INSERTED.OwnerID Values(@Name)", entity); foreach(var project in entity.Related) { connectionString.Execute( $"INSERT INTO tbl_project(Name, OwnerId) Values(@Name, @OwnerId)", new{Name = project.Name, OwnerId = scope_identity }); } } scope.Commit(); } }</code>
위 내용은 외래 키 제약 조건이 있는 중첩된 대량 삽입을 처리하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!