在父子表中插入資料
本範例的目標是從傳入的 UDT (@tEmployeeData) 插入資料到多個表中,確保父子記錄之間的正確對應。
解決映射問題
為了建立必要的映射,我們在 UDT 中新增一個臨時 employeeId 列,並用連續值填充。此外,我們建立一個表變數 (@EmployeeidMap) 來對應 UDT 中的暫存 employee ID 與目標表中產生的實際 employee ID。
填入主表
我們利用 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 連接以取得實際的 employee ID,我們用它來填入 @ParentEmployeeDepartment 表。類似地,我們將 @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中文網其他相關文章!