Práce se systémově verziovanými časovými tabulkami optimalizovanými pro paměť
platí pro: SQL Server 2016 (13.x) a novější
azure SQL Managed Instance
Tento článek popisuje, jak se práce s paměťově optimalizovanou systémově verzovanou časovou tabulkou liší od práce se systémově verzovanou časovou tabulkou založenou na disku.
Poznámka
Dočasné tabulky optimalizované pro paměť jsou k dispozici pouze v SQL Serveru a azure SQL Managed Instance. Tabulky optimalizované pro paměť a dočasné tabulky jsou nezávisle dostupné ve službě Azure SQL Database.
Zjišťování metadat
Chcete-li zjistit metadata o paměťově optimalizované systémově verzované časové tabulce, je nutné kombinovat informace z sys.tables a sys.internal_tables. Dočasná tabulka se systémovou verzí se prezentuje jako parent_object_id interní tabulky historie v paměti.
Tento příklad ukazuje, jak dotazovat a spojit tyto tabulky.
SELECT SCHEMA_NAME(T1.schema_id) AS TemporalTableSchema,
OBJECT_NAME(IT.parent_object_id) AS TemporalTableName,
T1.object_id AS TemporalTableObjectId,
IT.Name AS InternalHistoryStagingName,
SCHEMA_NAME(T2.schema_id) AS HistoryTableSchema,
OBJECT_NAME(T1.history_table_id) AS HistoryTableName
FROM sys.internal_tables IT
INNER JOIN sys.tables T1
ON IT.parent_object_id = T1.object_id
INNER JOIN sys.tables T2
ON T1.history_table_id = T2.object_id
WHERE T1.is_memory_optimized = 1
AND T1.temporal_type = 2;
Úprava dat
Dočasné tabulky optimalizované pro paměť je možné upravit pomocí nativně zkompilovaných uložených procedur, které umožňují převést nečasově optimalizované tabulky pro paměť a zachovat stávající nativně uložené procedury.
Tento příklad, jak lze dříve vytvořenou tabulku upravit v nativně zkompilovaném modulu.
CREATE PROCEDURE dbo.UpdateFXCurrencyPair (
@ProviderID INT,
@CurrencyID1 INT,
@CurrencyID2 INT,
@BidRate DECIMAL(8, 4),
@AskRate DECIMAL(8, 4)
)
WITH NATIVE_COMPILATION, SCHEMABINDING,
EXECUTE AS OWNER
AS
BEGIN ATOMIC
WITH (
TRANSACTION ISOLATION LEVEL = SNAPSHOT,
LANGUAGE = N'English'
)
UPDATE dbo.FXCurrencyPairs
SET AskRate = @AskRate,
BidRate = @BidRate
WHERE ProviderID = @ProviderID
AND CurrencyID1 = @CurrencyID1
AND CurrencyID2 = @CurrencyID2
END
GO;
Související obsah
- Systémově verzované časové tabulky s tabulkami optimalizovanými pro paměť
- Vytvoření paměťově optimalizované systémově verzované časové tabulky
- Monitorování paměťově optimalizovaných systémově verzovaných časových tabulek
- výkon systémem verzovaných paměťově optimalizovaných časových tabulek
- dočasné tabulky
- kontroly konzistence systému časových tabulek
- Správa uchovávání historických dat v systémově verzovaných temporálních tabulkách
- Zobrazení a funkce metadat temporálních tabulek