मैं इस सुविधा से परिचित नहीं हूँ, लेकिन यदि आपकी समस्या CHANGETABLE()
का उपयोग करके एकाधिक तालिकाओं को क्वेरी करने का तरीका है तो मुझे लगता है कि आप सभी टेबल नामों पर लूप करने के लिए संग्रहीत प्रक्रिया का उपयोग कर सकते हैं और गतिशील एसक्यूएल का उपयोग कर क्वेरी चला सकते हैं:
declare
@sql nvarchar(max),
@parameters nvarchar(max),
@TableName nvarchar(128),
@Version bigint
set @Version = CHANGE_TRACKING_CURRENT_VERSION()
declare Tables cursor local fast_forward
for
select name from sys.tables where... -- add conditions here if necessary
open Tables
fetch next from Tables into @TableName
while @@fetch_status = 0
begin
set @sql = N'select * from CHANGETABLE(CHANGES ' + quotename(@TableName) + ', @LastVersion)ct order by sys_change_version desc'
set @parameters = N'@LastVersion bigint'
exec sp_executesql @sql, @parameters, @LastVersion = @Version
fetch next from Tables into @TableName
end
close Tables
deallocate Tables
आप इसे INSERT
. के साथ जोड़ सकते हैं डायनामिक SQL में परिणामों को उस तालिका में लिखने के लिए जिसे आप रिपोर्टिंग और विश्लेषण के लिए क्वेरी करते हैं।