Créer une table temporelle à mémoire optimisée avec version système
S’applique à : SQL Server 2016 (13.x) et versions ultérieures Azure SQL Database Azure SQL Managed Instance
Comme pour la création d'une table d'historique sur disque, vous pouvez créer une table temporelle à mémoire optimisée de plusieurs façons.
Pour créer des tables à mémoire optimisée, vous devez d’abord créer le Groupe de fichiers mémoire optimisé.
Créer une table temporelle mémoire optimisée avec une table de l’historique par défaut
La création d’une table temporelle avec une table de l’historique par défaut est une option pratique lorsque vous voulez contrôler l’affectation des noms. Elle dépend toujours du système pour créer la table de l’historique avec la configuration par défaut. Dans l’exemple ci-dessous, une nouvelle table temporelle avec contrôle de version du système de mémoire optimisée est liée à une nouvelle table de l’historique basée sur des disques.
CREATE SCHEMA History;
GO
CREATE TABLE dbo.Department (
DepartmentNumber CHAR(10) NOT NULL PRIMARY KEY NONCLUSTERED,
DepartmentName VARCHAR(50) NOT NULL,
ManagerID INT NULL,
ParentDepartmentNumber CHAR(10) NULL,
ValidFrom DATETIME2 GENERATED ALWAYS AS ROW START HIDDEN NOT NULL,
ValidTo DATETIME2 GENERATED ALWAYS AS ROW END HIDDEN NOT NULL,
PERIOD FOR SYSTEM_TIME(ValidFrom, ValidTo)
)
WITH (
MEMORY_OPTIMIZED = ON,
DURABILITY = SCHEMA_AND_DATA,
SYSTEM_VERSIONING = ON (HISTORY_TABLE = History.DepartmentHistory)
);
Créer une table temporelle mémoire optimisée avec une table d’historique existante
Vous pouvez créer une table temporelle liée à une table d’historique existante lorsque vous souhaitez ajouter le contrôle de version système à l’aide d’une table existante. Ce scénario est utile lorsque vous souhaitez migrer une solution temporelle personnalisée vers la prise en charge intégrée. Dans l’exemple ci-dessous, une table temporelle est créée et liée à une table de l’historique existante.
--Existing table
CREATE TABLE Department_History (
DepartmentNumber CHAR(10) NOT NULL,
DepartmentName VARCHAR(50) NOT NULL,
ManagerID INT NULL,
ParentDepartmentNumber CHAR(10) NULL,
ValidFrom DATETIME2 NOT NULL,
ValidTo DATETIME2 NOT NULL
);
--Temporal table
CREATE TABLE Department (
DepartmentNumber CHAR(10) NOT NULL PRIMARY KEY NONCLUSTERED,
DepartmentName VARCHAR(50) NOT NULL,
ManagerID INT NULL,
ParentDepartmentNumber CHAR(10) NULL,
ValidFrom DATETIME2 GENERATED ALWAYS AS ROW START HIDDEN NOT NULL,
ValidTo DATETIME2 GENERATED ALWAYS AS ROW END HIDDEN NOT NULL,
PERIOD FOR SYSTEM_TIME(ValidFrom, ValidTo)
)
WITH (
SYSTEM_VERSIONING = ON (
HISTORY_TABLE = dbo.Department_History,
DATA_CONSISTENCY_CHECK = ON
),
MEMORY_OPTIMIZED = ON,
DURABILITY = SCHEMA_AND_DATA
);
Contenu connexe
- Tables temporelles avec version gérée par le système avec tables à mémoire optimisée
- Travailler avec les tables temporelles avec versions gérées par le système et à mémoire optimisée
- Surveiller des tables temporelles avec contrôle de version par le système à mémoire optimisée
- Performances des tables temporelles optimisées en mémoire avec gestion de version par le système
- Tables temporelles
- Vérifications de cohérence système des tables temporelles
- Gérer la rétention des données d'historique dans les tables temporelles avec contrôle de version par le système
- Vues et fonctions des métadonnées des tables temporelles