Remarque
L’accès à cette page nécessite une autorisation. Vous pouvez essayer de vous connecter ou de modifier des répertoires.
L’accès à cette page nécessite une autorisation. Vous pouvez essayer de modifier des répertoires.
Les données peuvent être stockées à l’aide des algorithmes de stockage fournis par les tables et index partitionnés. Le partitionnement permet de rendre des tables et des index volumineux plus gérables et plus évolutifs.
Partitionnement d’index et de table
La fonctionnalité permet à l’index et aux données de table d’être réparties entre plusieurs groupes de fichiers dans des partitions. Une fonction de partition définit la façon dont les lignes d’une table ou d’un index sont mappées à un ensemble de partitions en fonction des valeurs de certaines colonnes, appelées colonnes de partitionnement. Un schéma de partition mappe chaque partition spécifiée par la fonction de partition à un groupe de fichiers. Cela vous permet de développer des stratégies d’archivage qui permettent aux tables d’être mises à l’échelle entre les groupes de fichiers, et par conséquent des appareils physiques.
L’objet Database contient une collection d’objets qui représentent les fonctions de PartitionFunction partition implémentées et une collection d’objets PartitionScheme qui décrivent comment les données sont mappées aux groupes de fichiers.
Chaque Table et Index objet spécifie le schéma de partition qu’il utilise dans la PartitionScheme propriété et spécifie les colonnes dans le PartitionSchemeParameterCollection.
Exemple :
Pour l’exemple de code suivant, vous devez sélectionner l’environnement de programmation, le modèle de programmation et le langage de programmation pour créer votre application. Pour plus d’informations, consultez Créer un projet SMO Visual Basic dans Visual Studio .NET et créer un projet SMO Visual C# dans Visual Studio .NET.
Configuration d’un schéma de partition pour une table en Visual Basic
L’exemple de code montre comment créer une fonction de partition et un schéma de partition pour la TransactionHistory table dans l’exemple de base de données AdventureWorks2012. Les partitions sont divisées par date avec l’intention de séparer les anciens enregistrements dans la TransactionHistoryArchive table.
Configuration d’un schéma de partition pour une table dans Visual C#
L’exemple de code montre comment créer une fonction de partition et un schéma de partition pour la TransactionHistory table dans l’exemple de base de données AdventureWorks2012. Les partitions sont divisées par date avec l’intention de séparer les anciens enregistrements dans la TransactionHistoryArchive table.
{
//Connect to the local, default instance of SQL Server.
Server srv;
srv = new Server();
//Reference the AdventureWorks2012 database.
Database db;
db = srv.Databases("AdventureWorks2012");
//Define and create three new file groups on the database.
FileGroup fg2;
fg2 = new FileGroup(db, "Second");
fg2.Create();
FileGroup fg3;
fg3 = new FileGroup(db, "Third");
fg3.Create();
FileGroup fg4;
fg4 = new FileGroup(db, "Fourth");
fg4.Create();
//Define a partition function by supplying the parent database and name arguments in the constructor.
PartitionFunction pf;
pf = new PartitionFunction(db, "TransHistPF");
//Add a partition function parameter that specifies the function uses a DateTime range type.
PartitionFunctionParameter pfp;
pfp = new PartitionFunctionParameter(pf, DataType.DateTime);
pf.PartitionFunctionParameters.Add(pfp);
//Specify the three dates that divide the data into four partitions.
object[] val;
val = new object[] {"1/1/2003", "1/1/2004", "1/1/2005"};
pf.RangeValues = val;
//Create the partition function.
pf.Create();
//Define a partition scheme by supplying the parent database and name arguments in the constructor.
PartitionScheme ps;
ps = new PartitionScheme(db, "TransHistPS");
//Specify the partition function and the filegroups required by the partition scheme.
ps.PartitionFunction = "TransHistPF";
ps.FileGroups.Add("PRIMARY");
ps.FileGroups.Add("second");
ps.FileGroups.Add("Third");
ps.FileGroups.Add("Fourth");
//Create the partition scheme.
ps.Create();
}
Configuration d’un schéma de partition pour une table dans PowerShell
L’exemple de code montre comment créer une fonction de partition et un schéma de partition pour la TransactionHistory table dans l’exemple de base de données AdventureWorks2012. Les partitions sont divisées par date avec l’intention de séparer les anciens enregistrements dans la TransactionHistoryArchive table.
# Set the path context to the local, default instance of SQL Server.
CD \sql\localhost\default
#Get a server object which corresponds to the default instance
$srv = New-Object -TypeName Microsoft.SqlServer.Management.SMO.Server
$db = $srv.Databases["AdventureWorks"]
#Create four filegroups
$fg1 = New-Object -TypeName Microsoft.SqlServer.Management.SMO.Filegroup -argumentlist $db, "First"
$fg2 = New-Object -TypeName Microsoft.SqlServer.Management.SMO.Filegroup -argumentlist $db, "Second"
$fg3 = New-Object -TypeName Microsoft.SqlServer.Management.SMO.Filegroup -argumentlist $db, "Third"
$fg4 = New-Object -TypeName Microsoft.SqlServer.Management.SMO.Filegroup -argumentlist $db, "Fourth"
#Define a partition function by supplying the parent database and name arguments in the constructor.
$pf = New-Object -TypeName Microsoft.SqlServer.Management.SMO.PartitionFunction -argumentlist $db, "TransHistPF"
$T = [Microsoft.SqlServer.Management.SMO.DataType]::DateTime
$T
$T.GetType()
#Add a partition function parameter that specifies the function uses a DateTime range type.
$pfp = New-Object -TypeName Microsoft.SqlServer.Management.SMO.PartitionFunctionParameter -argumentlist $pf, $T
#Specify the three dates that divide the data into four partitions.
#Create an array of type object to hold the partition data
$val = "1/1/2003"."1/1/2004","1/1/2005"
$pf.RangeValues = $val
$pf
#Create the partition function
$pf.Create()
#Create partition scheme
$ps = New-Object -TypeName Microsoft.SqlServer.Management.SMO.PartitionScheme -argumentlist $db, "TransHistPS"
$ps.PartitionFunction = "TransHistPF"
#add the filegroups to the scheme
$ps.FileGroups.Add("PRIMARY")
$ps.FileGroups.Add("Second")
$ps.FileGroups.Add("Third")
$ps.FileGroups.Add("Fourth")
#Create it at the server
$ps.Create()