집 >데이터 베이스 >MySQL 튜토리얼 >올바른 매핑을 사용하여 상위 및 하위 테이블에 데이터를 효율적으로 삽입하는 방법은 무엇입니까?
상위-하위 테이블에 데이터 삽입
이 예의 목표는 수신 UDT(@tEmployeeData)의 데이터를 여러 테이블에 삽입하여 상위 레코드와 하위 레코드 간의 올바른 매핑을 보장하는 것입니다.
매핑 문제 해결
필요한 매핑을 설정하기 위해 UDT에 임시 직원 ID 열을 추가하고 연속 값으로 채웁니다. 또한 UDT의 임시 직원 ID를 대상 테이블에서 생성된 실제 직원 ID와 매핑하기 위해 테이블 변수(@EmployeeidMap)를 생성합니다.
메인 테이블 채우기
MERGE를 활용하여 @MainEmployee 테이블을 삽입된 데이터와 소스 데이터의 값으로 채웁니다. 이를 통해 생성된 EmployeeID 값을 캡처하고 동시에 매핑 테이블을 채울 수 있습니다.
<code class="language-sql">MERGE INTO @MainEmployee USING @tEmployeeData AS sourceData ON 1 = 0 WHEN NOT MATCHED THEN INSERT (FirstName, LastName) VALUES (sourceData.FirstName, sourceData.LastName) OUTPUT sourceData.EmployeeId, inserted.EmployeeID INTO @EmployeeidMap (temp_id, id);</code>
상위-하위 테이블에 매핑 및 삽입
그런 다음 @tEmployeeData를 @EmployeeidMap과 결합하여 @ParentEmployeeDepartment 테이블을 채우는 데 사용하는 실제 직원 ID를 가져옵니다. 마찬가지로 @ParentEmployeeDepartment를 @tEmployeeData와 연결하여 상위 ID를 하위 데이터에 매핑하고 해당 데이터를 @ChildEmployeeDepartmentTypeA 및 @ChildEmployeeDepartmentTypeB에 삽입합니다.
테스트 삽입
매핑이 성공했는지 확인하기 위해 UDT 데이터를 매핑 및 대상 테이블과 조인하는 쿼리를 실행합니다.
<code class="language-sql">SELECT FirstName, LastName, SentData.DepartmentType As [部门类型], DepartmentBuilding As 建筑物, DepartmentEmployeeLevel As [员工级别], DepartmentTypeAMetadata As [A 元数据], DepartmentTypeBMetadata As [B 元数据], SentData.EmployeeId As 临时ID, EmpMap.id As [员工ID], DeptMap.ParentEmployeeDepartmentID As [部门ID] FROM @tEmployeeData SentData INNER JOIN @EmployeeidMap EmpMap ON SentData.EmployeeId = temp_id INNER JOIN @ParentEmployeeDepartment DeptMap ON EmpMap.id = DeptMap.EmployeeID</code>
이 접근 방식을 사용하면 하위 데이터가 해당 상위 레코드에 올바르게 매핑되는 동시에 불필요한 행별 작업을 방지하여 성능을 최적화할 수 있습니다.
위 내용은 올바른 매핑을 사용하여 상위 및 하위 테이블에 데이터를 효율적으로 삽입하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!