在預存過程中高效填充父表和子表
本文檔概述了一種解決方案,可利用使用者定義的表格類型 (UDT) 進行資料輸入,從而有效地將資料插入到預存程序中的父表和子表中。 此方法解決了維護資料完整性和避免與逐行操作相關的效能瓶頸的挑戰。
挑戰:資料完整性與效能
挑戰在於如何在預存程序中將資料從 UDT 準確地對應到多個相關表(父表及其關聯的子表)。 簡單的逐行插入可能效率低下且容易出錯,尤其是在處理大型資料集時。
解:多步驟方法
此解決方案採用多步驟流程來確保效率和資料完整性:
增強 UDT: 將臨時 ID 欄位 (temp_id
) 新增至 UDT。這充當 UDT 中每一行的唯一標識符,對於在整個插入過程中追蹤資料至關重要。
使用 MERGE
進行父表插入: MERGE
語句有效地將資料插入父表 (@MainEmployee
) 中。 至關重要的是,它的 OUTPUT
子句捕獲臨時 ID(來自 UDT 的 temp_id
)和來自父表的新生成的 EmployeeID
。
建立映射表: OUTPUT
語句中的 MERGE
資料填充臨時映射表 (@EmployeeidMap
)。該表將臨時 temp_id
連結到父表中產生的實際 EmployeeID
。
具有ID 映射的父表填充: 然後使用@EmployeeidMap
表將UDT 資料與父表(@ParentEmployeeDepartment
) 連接,確保將正確的EmployeeID
分配給每個父表記錄一下。
子表填入: 最後,使用 @ChildEmployeeDepartmentTypeA
和 @ChildEmployeeDepartmentTypeB
表的聯結來填入子表(@EmployeeidMap
、@ParentEmployeeDepartment
)。這在父記錄和子記錄之間建立了必要的關係。
說明性程式碼範例:
以下程式碼示範了這種增強的方法:
<code class="language-sql">CREATE TYPE dbo.tEmployeeData AS TABLE ( FirstName NVARCHAR(50), LastName NVARCHAR(50), DepartmentType NVARCHAR(10), DepartmentBuilding NVARCHAR(50), DepartmentEmployeeLevel NVARCHAR(10), DepartmentTypeAMetadata NVARCHAR(100), DepartmentTypeBMetadata NVARCHAR(100), temp_id INT IDENTITY(1,1) -- Added temporary ID column ) GO CREATE PROC dbo.EmployeeImport (@tEmployeeData dbo.tEmployeeData READONLY) AS BEGIN -- ... (Temporary table declarations remain the same as in the original example) ... -- MERGE into @MainEmployee table MERGE INTO @MainEmployee USING @tEmployeeData AS sourceData ON 1 = 0 WHEN NOT MATCHED THEN INSERT (FirstName, LastName) VALUES (sourceData.FirstName, sourceData.LastName) OUTPUT sourceData.temp_id, inserted.EmployeeID INTO @EmployeeidMap; -- ... (Remaining INSERT statements adjusted to use @EmployeeidMap for joining) ... END GO</code>
這種改進的策略保證了高效、準確的資料插入,保持父表和子表之間的引用完整性,同時有效處理潛在的大型資料集。
以上是如何在預存過程中使用使用者定義的表格類型有效率地將資料插入父子表?的詳細內容。更多資訊請關注PHP中文網其他相關文章!