>데이터 베이스 >MySQL 튜토리얼 >외래 키 제약 조건이 있는 중첩된 대량 삽입을 처리하는 방법은 무엇입니까?

외래 키 제약 조건이 있는 중첩된 대량 삽입을 처리하는 방법은 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2025-01-13 07:42:43266검색

How to Handle Nested Bulk Inserts with Foreign Key Constraints?

중첩된 일괄 삽입의 한 가지 과제는 삽입 순서입니다. 부모와 자식 테이블 사이에 외래 키 참조를 사용하여 테이블을 생성한다고 가정해 보겠습니다. 일반적으로 하위 레코드를 삽입하려면 상위 레코드가 있어야 합니다. 이 문제를 처리하려면 상위 레코드를 먼저 삽입한 다음 하위 레코드를 삽입해야 합니다.

문제는 상위 레코드 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.