DbDataAdapter.FillSchema DbDataAdapter.FillSchema DbDataAdapter.FillSchema Method

Définition

Ajoute un DataTable à un DataSet et configure le schéma pour établir une correspondance dans la source de données.Adds a DataTable to a DataSet and configures the schema to match that in the data source.

Surcharges

FillSchema(DataSet, SchemaType, IDbCommand, String, CommandBehavior) FillSchema(DataSet, SchemaType, IDbCommand, String, CommandBehavior) FillSchema(DataSet, SchemaType, IDbCommand, String, CommandBehavior)

Ajoute un DataTable spécifié DataSet et configure le schéma pour correspondre à celui de la source de données en fonction spécifié SchemaType.Adds a DataTable to the specified DataSet and configures the schema to match that in the data source based on the specified SchemaType.

FillSchema(DataTable, SchemaType, IDbCommand, CommandBehavior) FillSchema(DataTable, SchemaType, IDbCommand, CommandBehavior) FillSchema(DataTable, SchemaType, IDbCommand, CommandBehavior)

Configure le schéma spécifié DataTable en fonction du SchemaType, chaîne de commande et CommandBehavior valeurs.Configures the schema of the specified DataTable based on the specified SchemaType, command string, and CommandBehavior values.

FillSchema(DataSet, SchemaType, String) FillSchema(DataSet, SchemaType, String) FillSchema(DataSet, SchemaType, String)

Ajoute un DataTable au DataSet spécifié et configure le schéma pour qu’il corresponde à celui de la source de données en fonction du SchemaType et du DataTable spécifiés.Adds a DataTable to the specified DataSet and configures the schema to match that in the data source based upon the specified SchemaType and DataTable.

FillSchema(DataTable, SchemaType) FillSchema(DataTable, SchemaType) FillSchema(DataTable, SchemaType)

Configure le schéma du DataTable spécifié en fonction du SchemaType spécifié.Configures the schema of the specified DataTable based on the specified SchemaType.

FillSchema(DataSet, SchemaType) FillSchema(DataSet, SchemaType) FillSchema(DataSet, SchemaType)

Ajoute un DataTable nommé « Table » au DataSet spécifié et configure le schéma pour qu’il corresponde à celui de la source de données en fonction du SchemaType spécifié.Adds a DataTable named "Table" to the specified DataSet and configures the schema to match that in the data source based on the specified SchemaType.

FillSchema(DataSet, SchemaType, IDbCommand, String, CommandBehavior) FillSchema(DataSet, SchemaType, IDbCommand, String, CommandBehavior) FillSchema(DataSet, SchemaType, IDbCommand, String, CommandBehavior)

Ajoute un DataTable spécifié DataSet et configure le schéma pour correspondre à celui de la source de données en fonction spécifié SchemaType.Adds a DataTable to the specified DataSet and configures the schema to match that in the data source based on the specified SchemaType.

protected:
 virtual cli::array <System::Data::DataTable ^> ^ FillSchema(System::Data::DataSet ^ dataSet, System::Data::SchemaType schemaType, System::Data::IDbCommand ^ command, System::String ^ srcTable, System::Data::CommandBehavior behavior);
protected virtual System.Data.DataTable[] FillSchema (System.Data.DataSet dataSet, System.Data.SchemaType schemaType, System.Data.IDbCommand command, string srcTable, System.Data.CommandBehavior behavior);
override this.FillSchema : System.Data.DataSet * System.Data.SchemaType * System.Data.IDbCommand * string * System.Data.CommandBehavior -> System.Data.DataTable[]

Paramètres

dataSet
DataSet DataSet DataSet

DataSet à remplir avec le schéma à partir de la source de données.The DataSet to be filled with the schema from the data source.

schemaType
SchemaType SchemaType SchemaType

Une des valeurs de SchemaType.One of the SchemaType values.

command
IDbCommand IDbCommand IDbCommand

L’instruction SQL SELECT utilisée pour extraire des lignes à partir de la source de données.The SQL SELECT statement used to retrieve rows from the data source.

srcTable
String String String

Le nom de la table source à utiliser pour le mappage de table.The name of the source table to use for table mapping.

behavior
CommandBehavior CommandBehavior CommandBehavior

Une des valeurs de CommandBehavior.One of the CommandBehavior values.

Retours

Un tableau de DataTable les objets qui contiennent des informations de schéma retournées par la source de données.An array of DataTable objects that contain schema information returned from the data source.

Remarques

Le FillSchema méthode récupère le schéma de la source de données en utilisant le SelectCommand.The FillSchema method retrieves the schema from the data source using the SelectCommand. L’objet de connexion associé le SelectCommand doit être valide, mais elle ne doit pas être ouvert.The connection object associated with the SelectCommand must be valid, but it does not need to be open. Si la connexion est fermée avant FillSchema est appelée, elle est ouverte pour récupérer les données, puis fermé.If the connection is closed before FillSchema is called, it is opened to retrieve data, then closed. Si la connexion est ouverte avant FillSchema est appelée, elle reste ouverte.If the connection is open before FillSchema is called, it remains open.

Un FillSchema opération ajoute une DataTable vers la destination DataSet.A FillSchema operation adds a DataTable to the destination DataSet. Il ajoute ensuite les colonnes à la DataColumnCollection de la DataTableet configure les éléments suivants DataColumn propriétés si elles existent dans la source de données :It then adds columns to the DataColumnCollection of the DataTable, and configures the following DataColumn properties if they exist at the data source:

FillSchema configure également le PrimaryKey et Constraints propriétés selon les règles suivantes :FillSchema also configures the PrimaryKey and Constraints properties according to the following rules:

  • Si une ou plusieurs colonnes clés primaires sont retournées par la SelectCommand, elles sont utilisées comme colonnes de clé primaire pour la DataTable.If one or more primary key columns are returned by the SelectCommand, they are used as the primary key columns for the DataTable.

  • Si aucune colonne clé primaire n’est retournés, mais sont des colonnes uniques, les colonnes uniques sont utilisées comme clé primaire si et uniquement si toutes les colonnes uniques sont non null.If no primary key columns are returned but unique columns are, the unique columns are used as the primary key if, and only if, all the unique columns are nonnullable. Si une des colonnes est nullable, un UniqueConstraint est ajouté à la ConstraintCollection, mais le PrimaryKey propriété n’est pas définie.If any of the columns are nullable, a UniqueConstraint is added to the ConstraintCollection, but the PrimaryKey property is not set.

  • Si les colonnes clés primaires et des colonnes uniques sont retournées, les colonnes clés primaires sont utilisés en tant que les colonnes clés primaires pour la DataTable.If both primary key columns and unique columns are returned, the primary key columns are used as the primary key columns for the DataTable.

Notez que les clés primaires et des contraintes uniques sont ajoutés à la ConstraintCollection selon les règles précédentes, mais autre contrainte des types ne sont pas ajoutés.Note that primary keys and unique constraints are added to the ConstraintCollection according to the preceding rules, but other constraint types are not added.

Si un unique clustered index est défini sur une ou plusieurs colonnes dans une table SQL Server et la contrainte de clé primaire est définie sur un ensemble distinct de colonnes, les noms des colonnes dans l’index cluster seront retourné.If a unique clustered index is defined on a column or columns in a SQL Server table and the primary key constraint is defined on a separate set of columns, then the names of the columns in the clustered index will be returned. Pour renvoyer l’ou les noms des colonnes de clé primaire, utilisez un indicateur de requête avec l’instruction SELECT qui spécifie le nom de l’index de clé primaire.To return the name or names of the primary key columns, use a query hint with the SELECT statement that specifies the name of the primary key index. Pour plus d’informations sur la spécification des indicateurs de requête, consultez l’indicateur de requête (Transact-SQL).For more information about specifying query hints, see Query Hint (Transact-SQL).

Si le IDataAdapter rencontre des colonnes dupliquées lors du remplissage un DataTable, il génère des noms pour les colonnes suivantes, selon le modèle »columnname1 », «columnname2 », »columnname3 » et ainsi de suite.If the IDataAdapter encounters duplicate columns while populating a DataTable, it generates names for the subsequent columns, using the pattern "columnname1", "columnname2", "columnname3", and so on. Si les données entrantes contiennent des colonnes sans nom, ils sont placés dans le DataSet selon le modèle « Column1 », « Column2 » et ainsi de suite.If the incoming data contains unnamed columns, they are placed in the DataSet according to the pattern "Column1", "Column2", and so on. Lorsque plusieurs jeux de résultats est ajoutés à la DataSet chaque jeu de résultats est placé dans une table distincte.When multiple result sets are added to the DataSet each result set is placed in a separate table. Jeux de résultats supplémentaires sont nommés en ajoutant des valeurs intégrales au nom de table spécifié (par exemple, « Table », « Table1 », « Table2 » et ainsi de suite.).Additional result sets are named by appending integral values to the specified table name (for example, "Table", "Table1", "Table2", and so on.). Applications à l’aide des noms de colonne et de table devraient vous assurer que tout conflit avec ces modèles d’affectation de noms ne se produit pas.Applications using column and table names should ensure that conflicts with these naming patterns does not occur.

Le FillSchema méthode prend en charge les scénarios où le DataSet contient plusieurs DataTable objets dont les noms diffèrent uniquement par la casse.The FillSchema method supports scenarios where the DataSet contains multiple DataTable objects whose names differ only by case. Dans ce cas, FillSchema effectue une comparaison respectant la casse pour rechercher la table correspondante et crée une table si aucune correspondance exacte n’existe.In such situations, FillSchema performs a case-sensitive comparison to find the corresponding table, and creates a new table if no exact match exists. Le code c# suivant illustre ce comportement.The following C# code illustrates this behavior.

DataSet dataset = new DataSet();  
dataset.Tables.Add("aaa");  
dataset.Tables.Add("AAA");  
adapter.FillSchema(dataset, "aaa"); // Fills the schema of "aaa", which already exists in the DataSet.  
adapter.FillSchema(dataset, "Aaa"); // Adds a new table called "Aaa".  

Si FillSchema est appelée et le DataSet contient un seul DataTable dont le nom diffère uniquement par la casse, qui DataTable est mis à jour.If FillSchema is called and the DataSet contains only one DataTable whose name differs only by case, that DataTable is updated. Dans ce scénario, la comparaison ne respecte pas la casse.In this scenario, the comparison is case insensitive. Le code c# suivant illustre ce comportement.The following C# code illustrates this behavior.

DataSet dataset = new DataSet();  
dataset.Tables.Add("aaa");  
adapter.FillSchema(dataset, "AAA"); // Fills the schema of table "aaa" because only one similarly named table is in the DataSet.  

FillSchema ne retourne pas de toutes les lignes.FillSchema does not return any rows. Utilisez le Fill méthode pour ajouter des lignes à un DataTable.Use the Fill method to add rows to a DataTable.

Notes

Lors du traitement d’instructions SQL par lots qui retournent plusieurs résultats, l’implémentation de FillSchema pour le fournisseur de données .NET Framework pour OLE DB récupère les informations de schéma pour seulement le premier résultat.When handling batch SQL statements that return multiple results, the implementation of FillSchema for the .NET Framework Data Provider for OLE DB retrieves schema information for only the first result. Pour récupérer les informations de schéma pour plusieurs résultats, utilisez Fill avec la MissingSchemaAction défini sur AddWithKey.To retrieve schema information for multiple results, use Fill with the MissingSchemaAction set to AddWithKey.

Lorsque vous utilisez FillSchema, le fournisseur de données .NET Framework pour SQL Server ajoute une clause FOR BROWSE à l’instruction en cours d’exécution.When using FillSchema, the .NET Framework Data Provider for SQL Server appends a FOR BROWSE clause to the statement being executed. L’utilisateur doit être conscient des effets secondaires potentiels, tels que les interférences avec l’utilisation d’instructions SET FMTONLY ON.The user should be aware of potential side effects, such as interference with the use of SET FMTONLY ON statements. Pour plus d’informations, consultez SET FMTONLY (Transact-SQL).For more information, see SET FMTONLY (Transact-SQL).

Notes pour les héritiers

Cette implémentation de la FillSchema(DataSet, SchemaType) méthode est protégée et est conçu pour une utilisation par un fournisseur de données .NET Framework.This implementation of the FillSchema(DataSet, SchemaType) method is protected and is designed for use by a .NET Framework data provider.

Voir aussi

FillSchema(DataTable, SchemaType, IDbCommand, CommandBehavior) FillSchema(DataTable, SchemaType, IDbCommand, CommandBehavior) FillSchema(DataTable, SchemaType, IDbCommand, CommandBehavior)

Configure le schéma spécifié DataTable en fonction du SchemaType, chaîne de commande et CommandBehavior valeurs.Configures the schema of the specified DataTable based on the specified SchemaType, command string, and CommandBehavior values.

protected:
 virtual System::Data::DataTable ^ FillSchema(System::Data::DataTable ^ dataTable, System::Data::SchemaType schemaType, System::Data::IDbCommand ^ command, System::Data::CommandBehavior behavior);
protected virtual System.Data.DataTable FillSchema (System.Data.DataTable dataTable, System.Data.SchemaType schemaType, System.Data.IDbCommand command, System.Data.CommandBehavior behavior);
override this.FillSchema : System.Data.DataTable * System.Data.SchemaType * System.Data.IDbCommand * System.Data.CommandBehavior -> System.Data.DataTable

Paramètres

dataTable
DataTable DataTable DataTable

DataTable à remplir avec le schéma à partir de la source de données.The DataTable to be filled with the schema from the data source.

schemaType
SchemaType SchemaType SchemaType

Une des valeurs de SchemaType.One of the SchemaType values.

command
IDbCommand IDbCommand IDbCommand

L’instruction SQL SELECT utilisée pour extraire des lignes à partir de la source de données.The SQL SELECT statement used to retrieve rows from the data source.

behavior
CommandBehavior CommandBehavior CommandBehavior

Une des valeurs de CommandBehavior.One of the CommandBehavior values.

Retours

A de DataTable objet qui contient les informations de schéma retournées par la source de données.A of DataTable object that contains schema information returned from the data source.

Remarques

Le FillSchema méthode récupère le schéma de la source de données en utilisant le SelectCommand.The FillSchema method retrieves the schema from the data source using the SelectCommand. L’objet de connexion associé le SelectCommand doit être valide, mais elle ne doit pas être ouvert.The connection object associated with the SelectCommand must be valid, but it does not need to be open. Si la connexion est fermée avant FillSchema est appelée, elle est ouverte pour récupérer les données, puis fermé.If the connection is closed before FillSchema is called, it is opened to retrieve data, then closed. Si la connexion est ouverte avant FillSchema est appelée, elle reste ouverte.If the connection is open before FillSchema is called, it remains open.

Un FillSchema opération ajoute une DataTable vers la destination DataSet.A FillSchema operation adds a DataTable to the destination DataSet. Il ajoute ensuite les colonnes à la DataColumnCollection de la DataTableet configure les éléments suivants DataColumn propriétés si elles existent dans la source de données :It then adds columns to the DataColumnCollection of the DataTable, and configures the following DataColumn properties if they exist at the data source:

FillSchema configure également le PrimaryKey et Constraints propriétés selon les règles suivantes :FillSchema also configures the PrimaryKey and Constraints properties according to the following rules:

  • Si une ou plusieurs colonnes clés primaires sont retournées par la SelectCommand, elles sont utilisées comme colonnes de clé primaire pour la DataTable.If one or more primary key columns are returned by the SelectCommand, they are used as the primary key columns for the DataTable.

  • Si aucune colonne clé primaire n’est retournés, mais sont des colonnes uniques, les colonnes uniques sont utilisées comme clé primaire si et uniquement si toutes les colonnes uniques sont non null.If no primary key columns are returned but unique columns are, the unique columns are used as the primary key if, and only if, all the unique columns are nonnullable. Si une des colonnes est nullable, un UniqueConstraint est ajouté à la ConstraintCollection, mais le PrimaryKey propriété n’est pas définie.If any of the columns are nullable, a UniqueConstraint is added to the ConstraintCollection, but the PrimaryKey property is not set.

  • Si les colonnes clés primaires et des colonnes uniques sont retournées, les colonnes clés primaires sont utilisés en tant que les colonnes clés primaires pour la DataTable.If both primary key columns and unique columns are returned, the primary key columns are used as the primary key columns for the DataTable.

Notez que les clés primaires et des contraintes uniques sont ajoutés à la ConstraintCollection selon les règles précédentes, mais autre contrainte des types ne sont pas ajoutés.Note that primary keys and unique constraints are added to the ConstraintCollection according to the preceding rules, but other constraint types are not added.

Si un unique clustered index est défini sur une ou plusieurs colonnes dans une table SQL Server et la contrainte de clé primaire est définie sur un ensemble distinct de colonnes, les noms des colonnes dans l’index cluster seront retourné.If a unique clustered index is defined on a column or columns in a SQL Server table and the primary key constraint is defined on a separate set of columns, then the names of the columns in the clustered index will be returned. Pour renvoyer l’ou les noms des colonnes de clé primaire, utilisez un indicateur de requête avec l’instruction SELECT qui spécifie le nom de l’index de clé primaire.To return the name or names of the primary key columns, use a query hint with the SELECT statement that specifies the name of the primary key index. Pour plus d’informations sur la spécification des indicateurs de requête, consultez l’indicateur de requête (Transact-SQL).For more information about specifying query hints, see Query Hint (Transact-SQL).

Si le IDataAdapter rencontre des colonnes dupliquées lors du remplissage un DataTable, il génère des noms pour les colonnes suivantes, selon le modèle »columnname1 », «columnname2 », »columnname3 » et ainsi de suite.If the IDataAdapter encounters duplicate columns while populating a DataTable, it generates names for the subsequent columns, using the pattern "columnname1", "columnname2", "columnname3", and so on. Si les données entrantes contiennent des colonnes sans nom, ils sont placés dans le DataSet selon le modèle « Column1 », « Column2 » et ainsi de suite.If the incoming data contains unnamed columns, they are placed in the DataSet according to the pattern "Column1", "Column2", and so on. Lorsque plusieurs jeux de résultats est ajoutés à la DataSet chaque jeu de résultats est placé dans une table distincte.When multiple result sets are added to the DataSet each result set is placed in a separate table. Jeux de résultats supplémentaires sont nommés en ajoutant des valeurs intégrales au nom de table spécifié (par exemple, « Table », « Table1 », « Table2 » et ainsi de suite.).Additional result sets are named by appending integral values to the specified table name (for example, "Table", "Table1", "Table2", and so on.). Applications à l’aide des noms de colonne et de table devraient vous assurer que tout conflit avec ces modèles d’affectation de noms ne se produit pas.Applications using column and table names should ensure that conflicts with these naming patterns does not occur.

FillSchema ne retourne pas de toutes les lignes.FillSchema does not return any rows. Utilisez le Fill méthode pour ajouter des lignes à un DataTable.Use the Fill method to add rows to a DataTable.

Notes

Lors du traitement d’instructions SQL par lots qui retournent plusieurs résultats, l’implémentation de FillSchema pour le fournisseur de données .NET Framework pour OLE DB récupère les informations de schéma pour seulement le premier résultat.When handling batch SQL statements that return multiple results, the implementation of FillSchema for the .NET Framework Data Provider for OLE DB retrieves schema information for only the first result. Pour récupérer les informations de schéma pour plusieurs résultats, utilisez Fill avec la MissingSchemaAction défini sur AddWithKey.To retrieve schema information for multiple results, use Fill with the MissingSchemaAction set to AddWithKey.

Lorsque vous utilisez FillSchema, le fournisseur de données .NET Framework pour SQL Server ajoute une clause FOR BROWSE à l’instruction en cours d’exécution.When using FillSchema, the .NET Framework Data Provider for SQL Server appends a FOR BROWSE clause to the statement being executed. L’utilisateur doit être conscient des effets secondaires potentiels, tels que les interférences avec l’utilisation d’instructions SET FMTONLY ON.The user should be aware of potential side effects, such as interference with the use of SET FMTONLY ON statements. Pour plus d’informations, consultez SET FMTONLY (Transact-SQL).For more information, see SET FMTONLY (Transact-SQL).

Notes pour les héritiers

Cette implémentation de la FillSchema(DataSet, SchemaType) méthode est protégée et est conçu pour une utilisation par un fournisseur de données .NET Framework.This implementation of the FillSchema(DataSet, SchemaType) method is protected and is designed for use by a .NET Framework data provider.

Voir aussi

FillSchema(DataSet, SchemaType, String) FillSchema(DataSet, SchemaType, String) FillSchema(DataSet, SchemaType, String)

Ajoute un DataTable au DataSet spécifié et configure le schéma pour qu’il corresponde à celui de la source de données en fonction du SchemaType et du DataTable spécifiés.Adds a DataTable to the specified DataSet and configures the schema to match that in the data source based upon the specified SchemaType and DataTable.

public:
 cli::array <System::Data::DataTable ^> ^ FillSchema(System::Data::DataSet ^ dataSet, System::Data::SchemaType schemaType, System::String ^ srcTable);
public System.Data.DataTable[] FillSchema (System.Data.DataSet dataSet, System.Data.SchemaType schemaType, string srcTable);
override this.FillSchema : System.Data.DataSet * System.Data.SchemaType * string -> System.Data.DataTable[]

Paramètres

dataSet
DataSet DataSet DataSet

DataSet où insérer le schéma.A DataSet to insert the schema in.

schemaType
SchemaType SchemaType SchemaType

Une des valeurs de SchemaType qui spécifient comment insérer le schéma.One of the SchemaType values that specify how to insert the schema.

srcTable
String String String

Le nom de la table source à utiliser pour le mappage de table.The name of the source table to use for table mapping.

Retours

Référence à une collection d’objets DataTable qui ont été ajoutés à DataSet.A reference to a collection of DataTable objects that were added to the DataSet.

Exceptions

Impossible de trouver une table source auprès de laquelle obtenir le schéma.A source table from which to get the schema could not be found.

Exemples

L’exemple suivant utilise la classe dérivée, SqlDataAdapter, pour remplir un DataSet avec le schéma et retourne un DataSet.The following example uses the derived class, SqlDataAdapter, to fill a DataSet with the schema, and returns a DataSet.

public static DataSet GetCustomerData(string dataSetName,
    string connectionString)
{
    DataSet dataSet = new DataSet(dataSetName);

    using (SqlConnection connection = new SqlConnection(connectionString))
    {
        SqlDataAdapter adapter = new SqlDataAdapter(
            "SELECT CustomerID, CompanyName, ContactName FROM dbo.Customers", connection);

        DataTableMapping mapping = adapter.TableMappings.Add("Table", "Customers");
        mapping.ColumnMappings.Add("CompanyName", "Name");
        mapping.ColumnMappings.Add("ContactName", "Contact");

        connection.Open();

        adapter.FillSchema(dataSet, SchemaType.Source, "Customers");
        adapter.Fill(dataSet);

        return dataSet;
    }
}
Private Function GetCustomerData(ByVal dataSetName As String, _
    ByVal connectionString As String) As DataSet

    Dim dataSet As DataSet = New DataSet(dataSetName)

    Using connection As SqlConnection = New SqlConnection(connectionString)

        Dim adapter As SqlDataAdapter = New SqlDataAdapter( _
           "SELECT CustomerID, CompanyName, ContactName FROM dbo.Customers", _
           connection)

        Dim mapping As DataTableMapping = adapter.TableMappings.Add( _
           "Table", "Customers")
        mapping.ColumnMappings.Add("CompanyName", "Name")
        mapping.ColumnMappings.Add("ContactName", "Contact")

        connection.Open()

        adapter.FillSchema(dataSet, SchemaType.Source, "Customers")
        adapter.Fill(dataSet)
        Return dataSet
    End Using
End Function

Remarques

Cette méthode récupère les informations de schéma à partir de la source de données en utilisant le SelectCommand.This method retrieves the schema information from the data source using the SelectCommand.

Un FillSchema opération ajoute une DataTable vers la destination DataSet.A FillSchema operation adds a DataTable to the destination DataSet. Il ajoute ensuite les colonnes à la DataColumnCollection de la DataTableet configure les éléments suivants DataColumn propriétés si elles existent dans la source de données :It then adds columns to the DataColumnCollection of the DataTable, and configures the following DataColumn properties if they exist at the data source:

FillSchema configure également le PrimaryKey et Constraints propriétés selon les règles suivantes :FillSchema also configures the PrimaryKey and Constraints properties according to the following rules:

  • Si une ou plusieurs colonnes clés primaires sont retournées par la SelectCommand, elles sont utilisées comme colonnes de clé primaire pour la DataTable.If one or more primary key columns are returned by the SelectCommand, they are used as the primary key columns for the DataTable.

  • Si aucune colonne clé primaire n’est retournés, mais sont des colonnes uniques, les colonnes uniques sont utilisées comme clé primaire si et uniquement si toutes les colonnes uniques sont non null.If no primary key columns are returned but unique columns are, the unique columns are used as the primary key if, and only if, all the unique columns are nonnullable. Si une des colonnes est nullable, un UniqueConstraint est ajouté à la ConstraintCollection, mais le PrimaryKey propriété n’est pas définie.If any of the columns are nullable, a UniqueConstraint is added to the ConstraintCollection, but the PrimaryKey property is not set.

  • Si les colonnes clés primaires et des colonnes uniques sont retournées, les colonnes clés primaires sont utilisés en tant que les colonnes clés primaires pour la DataTable.If both primary key columns and unique columns are returned, the primary key columns are used as the primary key columns for the DataTable.

Notez que les clés primaires et des contraintes uniques sont ajoutés à la ConstraintCollection selon les règles précédentes, mais autre contrainte des types ne sont pas ajoutés.Note that primary keys and unique constraints are added to the ConstraintCollection according to the preceding rules, but other constraint types are not added.

Si un unique clustered index est défini sur une ou plusieurs colonnes dans une table SQL Server et la contrainte de clé primaire est définie sur un ensemble distinct de colonnes, les noms des colonnes dans l’index cluster seront retourné.If a unique clustered index is defined on a column or columns in a SQL Server table and the primary key constraint is defined on a separate set of columns, then the names of the columns in the clustered index will be returned. Pour renvoyer l’ou les noms des colonnes de clé primaire, utilisez un indicateur de requête avec l’instruction SELECT qui spécifie le nom de l’index de clé primaire.To return the name or names of the primary key columns, use a query hint with the SELECT statement that specifies the name of the primary key index. Pour plus d’informations sur la spécification des indicateurs de requête, consultez l’indicateur de requête (Transact-SQL).For more information about specifying query hints, see Query Hint (Transact-SQL).

Informations de clé primaire sont utilisées pendant Fill pour rechercher et remplacer les lignes dont les colonnes clés correspondent.Primary key information is used during Fill to find and replace any rows whose key columns match. Si ce n’est pas le comportement souhaité, utilisez Fill sans demander les informations de schéma.If this is not the desired behavior, use Fill without requesting schema information.

Si le DbDataAdapter rencontre des colonnes dupliquées lors du remplissage un DataTable, il génère des noms pour les colonnes suivantes, selon le modèle »columnname1 », «columnname2 », »columnname3 » et ainsi de suite.If the DbDataAdapter encounters duplicate columns while populating a DataTable, it generates names for the subsequent columns, using the pattern "columnname1", "columnname2", "columnname3", and so on. Si les données entrantes contiennent des colonnes sans nom, ils sont placés dans le DataSet selon le modèle « Column1 », « Column2 » et ainsi de suite.If the incoming data contains unnamed columns, they are placed in the DataSet according to the pattern "Column1", "Column2", and so on. Lorsque plusieurs jeux de résultats est ajoutés à la DataSet chaque jeu de résultats est placé dans une table distincte.When multiple result sets are added to the DataSet each result set is placed in a separate table. Jeux de résultats supplémentaires sont nommés en ajoutant des valeurs intégrales au nom de table spécifié (par exemple, « Table », « Table1 », « Table2 » et ainsi de suite.).Additional result sets are named by appending integral values to the specified table name (for example, "Table", "Table1", "Table2", and so on.). Applications à l’aide des noms de colonne et de table devraient vous assurer que tout conflit avec ces modèles d’affectation de noms ne se produit pas.Applications using column and table names should ensure that conflicts with these naming patterns does not occur.

Le FillSchema méthode prend en charge les scénarios où le DataSet contient plusieurs DataTable objets dont les noms diffèrent uniquement par la casse.The FillSchema method supports scenarios where the DataSet contains multiple DataTable objects whose names differ only by case. Dans ce cas, FillSchema effectue une comparaison respectant la casse pour rechercher la table correspondante et crée une table si aucune correspondance exacte n’existe.In such situations, FillSchema performs a case-sensitive comparison to find the corresponding table, and creates a new table if no exact match exists. Le code c# suivant illustre ce comportement.The following C# code illustrates this behavior.

DataSet dataset = new DataSet();  
dataset.Tables.Add("aaa");  
dataset.Tables.Add("AAA");  
adapter.FillSchema(dataset, "aaa"); // Fills the schema of "aaa", which already exists in the DataSet.  
adapter.FillSchema(dataset, "Aaa"); // Adds a new table called "Aaa".  

Si FillSchema est appelée et le DataSet contient un seul DataTable dont le nom diffère uniquement par la casse, qui DataTable est mis à jour.If FillSchema is called and the DataSet contains only one DataTable whose name differs only by case, that DataTable is updated. Dans ce scénario, la comparaison ne respecte pas la casse.In this scenario, the comparison is case insensitive. Le code c# suivant illustre ce comportement.The following C# code illustrates this behavior.

DataSet dataset = new DataSet();  
dataset.Tables.Add("aaa");  
adapter.FillSchema(dataset, "AAA"); // Fills the schema of table "aaa" because only one similarly named table is in the DataSet.  

Le IDbConnection objet associé à la commande select doit être valide, mais il est inutile d’ouvrir.The IDbConnection object associated with the select command must be valid, but it does not need to open. Si le IDbConnection est fermé avant FillSchema est appelée, elle est ouverte pour récupérer les données, puis fermé.If the IDbConnection is closed before FillSchema is called, it is opened to retrieve data, then closed. Si la connexion est ouverte avant FillSchema est appelée, il est laissé ouvert.If the connection is open before FillSchema is called, it is left open.

Notes

Lors du traitement d’instructions SQL par lots qui retournent plusieurs résultats, l’implémentation de FillSchema pour le fournisseur de données .NET Framework pour OLE DB récupère les informations de schéma pour seulement le premier résultat.When handling batch SQL statements that return multiple results, the implementation of FillSchema for the .NET Framework Data Provider for OLE DB retrieves schema information for only the first result. Pour récupérer les informations de schéma pour plusieurs résultats, utilisez Fill avec la MissingSchemaAction défini sur AddWithKey.To retrieve schema information for multiple results, use Fill with the MissingSchemaAction set to AddWithKey.

Lorsque vous utilisez FillSchema, le fournisseur de données .NET Framework pour SQL Server ajoute une clause FOR BROWSE à l’instruction en cours d’exécution.When using FillSchema, the .NET Framework Data Provider for SQL Server appends a FOR BROWSE clause to the statement being executed. L’utilisateur doit être conscient des effets secondaires potentiels, tels que les interférences avec l’utilisation d’instructions SET FMTONLY ON.The user should be aware of potential side effects, such as interference with the use of SET FMTONLY ON statements. Pour plus d’informations, consultez SET FMTONLY (Transact-SQL).For more information, see SET FMTONLY (Transact-SQL).

Voir aussi

FillSchema(DataTable, SchemaType) FillSchema(DataTable, SchemaType) FillSchema(DataTable, SchemaType)

Configure le schéma du DataTable spécifié en fonction du SchemaType spécifié.Configures the schema of the specified DataTable based on the specified SchemaType.

public:
 System::Data::DataTable ^ FillSchema(System::Data::DataTable ^ dataTable, System::Data::SchemaType schemaType);
public System.Data.DataTable FillSchema (System.Data.DataTable dataTable, System.Data.SchemaType schemaType);
override this.FillSchema : System.Data.DataTable * System.Data.SchemaType -> System.Data.DataTable

Paramètres

dataTable
DataTable DataTable DataTable

DataTable à remplir avec le schéma à partir de la source de données.The DataTable to be filled with the schema from the data source.

schemaType
SchemaType SchemaType SchemaType

Une des valeurs de SchemaType.One of the SchemaType values.

Retours

DataTable qui contient les informations de schéma retournées par la source de données.A DataTable that contains schema information returned from the data source.

Exemples

L’exemple suivant utilise la classe dérivée, SqlDataAdapter, pour remplir un DataSet avec le schéma et retourne un DataTable.The following example uses the derived class, SqlDataAdapter, to fill a DataSet with the schema, and returns a DataTable.

public static DataTable GetCustomerData(string dataSetName,
    string connectionString)
{
    DataTable table = new DataTable(dataSetName);

    using (SqlConnection connection = new SqlConnection(connectionString))
    {
        SqlDataAdapter adapter = new SqlDataAdapter(
            "SELECT CustomerID, CompanyName, ContactName FROM dbo.Customers", connection);

        DataTableMapping mapping = adapter.TableMappings.Add("Table", "Customers");
        mapping.ColumnMappings.Add("CompanyName", "Name");
        mapping.ColumnMappings.Add("ContactName", "Contact");

        connection.Open();

        adapter.FillSchema(table, SchemaType.Mapped);
        adapter.Fill(table);
        return table;
    }
}
Private Function GetCustomerData(ByVal dataTableName As String, _
    ByVal connectionString As String) As DataTable

    Dim table As DataTable = New DataTable(dataTableName)

    Using connection As SqlConnection = New SqlConnection(connectionString)

        Dim adapter As SqlDataAdapter = New SqlDataAdapter( _
           "SELECT CustomerID, CompanyName, ContactName FROM dbo.Customers", _
           connection)

        Dim mapping As DataTableMapping = adapter.TableMappings.Add( _
           "Table", "Customers")
        mapping.ColumnMappings.Add("CompanyName", "Name")
        mapping.ColumnMappings.Add("ContactName", "Contact")

        connection.Open()

        adapter.FillSchema(table, SchemaType.Mapped)
        adapter.Fill(table)
        Return table
    End Using
End Function

Remarques

Le FillSchema méthode récupère le schéma de la source de données en utilisant le SelectCommand.The FillSchema method retrieves the schema from the data source using the SelectCommand. L’objet de connexion associé le SelectCommand doit être valide, mais elle ne doit pas être ouvert.The connection object associated with the SelectCommand must be valid, but it does not need to be open. Si la connexion est fermée avant FillSchema est appelée, elle est ouverte pour récupérer les données, puis fermé.If the connection is closed before FillSchema is called, it is opened to retrieve data, then closed. Si la connexion est ouverte avant FillSchema est appelée, elle reste ouverte.If the connection is open before FillSchema is called, it remains open.

Un FillSchema opération retourne un DataTable.A FillSchema operation returns a DataTable. Il ajoute ensuite les colonnes à la DataColumnCollection de la DataTableet configure les éléments suivants DataColumn propriétés si elles existent dans la source de données :It then adds columns to the DataColumnCollection of the DataTable, and configures the following DataColumn properties if they exist at the data source:

FillSchema configure également le PrimaryKey et Constraints propriétés selon les règles suivantes :FillSchema also configures the PrimaryKey and Constraints properties according to the following rules:

  • Si un PrimaryKey a déjà été défini pour le DataTable, ou le DataTable contient des données, le PrimaryKey propriété ne sera pas définie.If a PrimaryKey has already been defined for the DataTable, or the DataTable contains data, the PrimaryKey property will not be set.

  • Si une ou plusieurs colonnes clés primaires sont retournées par la SelectCommand, elles sont utilisées comme colonnes de clé primaire pour la DataTable.If one or more primary key columns are returned by the SelectCommand, they are used as the primary key columns for the DataTable.

  • Si aucune colonne clé primaire n’est retournés, mais sont des colonnes uniques, les colonnes uniques sont utilisées comme clé primaire si et uniquement si toutes les colonnes uniques sont non null.If no primary key columns are returned but unique columns are, the unique columns are used as the primary key if, and only if, all the unique columns are nonnullable. Si une des colonnes est nullable, un UniqueConstraint est ajouté à la ConstraintCollection, mais le PrimaryKey propriété n’est pas définie.If any of the columns are nullable, a UniqueConstraint is added to the ConstraintCollection, but the PrimaryKey property is not set.

  • Si les colonnes clés primaires et des colonnes uniques sont retournées, les colonnes clés primaires sont utilisés en tant que les colonnes clés primaires pour la DataTable.If both primary key columns and unique columns are returned, the primary key columns are used as the primary key columns for the DataTable.

Notez que les clés primaires et des contraintes uniques sont ajoutés à la ConstraintCollection selon les règles précédentes, mais autre contrainte des types ne sont pas ajoutés.Note that primary keys and unique constraints are added to the ConstraintCollection according to the preceding rules, but other constraint types are not added. Ce processus peut exiger plusieurs allers-retours au serveur.This process may require several round-trips to the server.

Si un unique clustered index est défini sur une ou plusieurs colonnes dans une table SQL Server et la contrainte de clé primaire est définie sur un ensemble distinct de colonnes, les noms des colonnes dans l’index cluster seront retourné.If a unique clustered index is defined on a column or columns in a SQL Server table and the primary key constraint is defined on a separate set of columns, then the names of the columns in the clustered index will be returned. Pour renvoyer l’ou les noms des colonnes de clé primaire, utilisez un indicateur de requête avec l’instruction SELECT qui spécifie le nom de l’index de clé primaire.To return the name or names of the primary key columns, use a query hint with the SELECT statement that specifies the name of the primary key index. Pour plus d’informations sur la spécification des indicateurs de requête, consultez l’indicateur de requête (Transact-SQL).For more information about specifying query hints, see Query Hint (Transact-SQL).

Si le DbDataAdapter rencontre des colonnes dupliquées lors du remplissage un DataTable, il génère des noms pour les colonnes suivantes, selon le modèle »columnname1 », «columnname2 », »columnname3 » et ainsi de suite.If the DbDataAdapter encounters duplicate columns while populating a DataTable, it generates names for the subsequent columns, using the pattern "columnname1", "columnname2", "columnname3", and so on. Si les données entrantes contiennent des colonnes sans nom, ils sont placés dans le DataSet selon le modèle « Column1 », « Column2 » et ainsi de suite.If the incoming data contains unnamed columns, they are placed in the DataSet according to the pattern "Column1", "Column2", and so on. Lorsque plusieurs jeux de résultats est ajoutés à la DataSet chaque jeu de résultats est placé dans une table distincte.When multiple result sets are added to the DataSet each result set is placed in a separate table. Jeux de résultats supplémentaires sont nommés en ajoutant des valeurs intégrales au nom de table spécifié (par exemple, « Table », « Table1 », « Table2 » et ainsi de suite.).Additional result sets are named by appending integral values to the specified table name (for example, "Table", "Table1", "Table2", and so on.). Applications à l’aide des noms de colonne et de table devraient vous assurer que tout conflit avec ces modèles d’affectation de noms ne se produit pas.Applications using column and table names should ensure that conflicts with these naming patterns does not occur.

FillSchema ne retourne pas de toutes les lignes.FillSchema does not return any rows. Utilisez le Fill méthode pour ajouter des lignes à un DataTable.Use the Fill method to add rows to a DataTable.

Notes

Lors du traitement d’instructions SQL par lots qui retournent plusieurs résultats, l’implémentation de FillSchema pour le fournisseur de données .NET Framework pour OLE DB récupère les informations de schéma pour seulement le premier résultat.When handling batch SQL statements that return multiple results, the implementation of FillSchema for the .NET Framework Data Provider for OLE DB retrieves schema information for only the first result. Pour récupérer les informations de schéma pour plusieurs résultats, utilisez Fill avec la MissingSchemaAction défini sur AddWithKey.To retrieve schema information for multiple results, use Fill with the MissingSchemaAction set to AddWithKey.

Lorsque vous utilisez FillSchema, le fournisseur de données .NET Framework pour SQL Server ajoute une clause FOR BROWSE à l’instruction en cours d’exécution.When using FillSchema, the .NET Framework Data Provider for SQL Server appends a FOR BROWSE clause to the statement being executed. L’utilisateur doit être conscient des effets secondaires potentiels, tels que les interférences avec l’utilisation d’instructions SET FMTONLY ON.The user should be aware of potential side effects, such as interference with the use of SET FMTONLY ON statements. Pour plus d’informations, consultez SET FMTONLY (Transact-SQL).For more information, see SET FMTONLY (Transact-SQL).

Voir aussi

FillSchema(DataSet, SchemaType) FillSchema(DataSet, SchemaType) FillSchema(DataSet, SchemaType)

Ajoute un DataTable nommé « Table » au DataSet spécifié et configure le schéma pour qu’il corresponde à celui de la source de données en fonction du SchemaType spécifié.Adds a DataTable named "Table" to the specified DataSet and configures the schema to match that in the data source based on the specified SchemaType.

public:
 override cli::array <System::Data::DataTable ^> ^ FillSchema(System::Data::DataSet ^ dataSet, System::Data::SchemaType schemaType);
public override System.Data.DataTable[] FillSchema (System.Data.DataSet dataSet, System.Data.SchemaType schemaType);
override this.FillSchema : System.Data.DataSet * System.Data.SchemaType -> System.Data.DataTable[]

Paramètres

dataSet
DataSet DataSet DataSet

DataSet où insérer le schéma.A DataSet to insert the schema in.

schemaType
SchemaType SchemaType SchemaType

Une des valeurs de SchemaType qui spécifient comment insérer le schéma.One of the SchemaType values that specify how to insert the schema.

Retours

Référence à une collection d’objets DataTable qui ont été ajoutés à DataSet.A reference to a collection of DataTable objects that were added to the DataSet.

Implémente

Exemples

L’exemple suivant utilise la classe dérivée, SqlDataAdapter, pour remplir un DataSet avec le schéma et retourne un DataSet.The following example uses the derived class, SqlDataAdapter, to fill a DataSet with the schema, and returns a DataSet.

public static DataSet GetCustomerData(string dataSetName,
    string connectionString)
{
    DataSet dataSet = new DataSet(dataSetName);

    using (SqlConnection connection = new SqlConnection(connectionString))
    {
        SqlDataAdapter adapter = new SqlDataAdapter(
            "SELECT CustomerID, CompanyName, ContactName FROM dbo.Customers", connection);

        DataTableMapping mapping = adapter.TableMappings.Add("Table", "Customers");
        mapping.ColumnMappings.Add("CompanyName", "Name");
        mapping.ColumnMappings.Add("ContactName", "Contact");

        connection.Open();

        adapter.FillSchema(dataSet, SchemaType.Mapped);
        adapter.Fill(dataSet);

        return dataSet;
    }
}
Private Function GetCustomerData(ByVal dataSetName As String, _
    ByVal connectionString As String) As DataSet

    Dim dataSet As DataSet = New DataSet(dataSetName)

    Using connection As SqlConnection = New SqlConnection(connectionString)
        Dim adapter As SqlDataAdapter = New SqlDataAdapter( _
           "SELECT CustomerID, CompanyName, ContactName FROM dbo.Customers", _
           connection)

        Dim mapping As DataTableMapping = adapter.TableMappings.Add( _
           "Table", "Customers")
        mapping.ColumnMappings.Add("CompanyName", "Name")
        mapping.ColumnMappings.Add("ContactName", "Contact")

        connection.Open()

        adapter.FillSchema(dataSet, SchemaType.Mapped)
        adapter.Fill(dataSet)
        Return dataSet
    End Using
End Function

Remarques

Cette méthode récupère les informations de schéma à partir de la source de données en utilisant le SelectCommand.This method retrieves the schema information from the data source using the SelectCommand.

Un FillSchema opération ajoute une DataTable vers la destination DataSet.A FillSchema operation adds a DataTable to the destination DataSet. Il ajoute ensuite les colonnes à la DataColumnCollection de la DataTableet configure les éléments suivants DataColumn propriétés si elles existent dans la source de données :It then adds columns to the DataColumnCollection of the DataTable, and configures the following DataColumn properties if they exist at the data source:

FillSchema configure également le PrimaryKey et Constraints propriétés selon les règles suivantes :FillSchema also configures the PrimaryKey and Constraints properties according to the following rules:

  • Si une ou plusieurs colonnes clés primaires sont retournées par la SelectCommand, elles sont utilisées comme colonnes de clé primaire pour la DataTable.If one or more primary key columns are returned by the SelectCommand, they are used as the primary key columns for the DataTable.

  • Si aucune colonne clé primaire n’est retournés, mais sont des colonnes uniques, les colonnes uniques sont utilisées comme clé primaire si et uniquement si toutes les colonnes uniques sont non null.If no primary key columns are returned but unique columns are, the unique columns are used as the primary key if, and only if, all the unique columns are nonnullable. Si une des colonnes est nullable, un UniqueConstraint est ajouté à la ConstraintCollection, mais le PrimaryKey propriété n’est pas définie.If any of the columns are nullable, a UniqueConstraint is added to the ConstraintCollection, but the PrimaryKey property is not set.

  • Si les colonnes clés primaires et des colonnes uniques sont retournées, les colonnes clés primaires sont utilisés en tant que les colonnes clés primaires pour la DataTable.If both primary key columns and unique columns are returned, the primary key columns are used as the primary key columns for the DataTable.

Notez que les clés primaires et des contraintes uniques sont ajoutés à la ConstraintCollection selon les règles précédentes, mais autre contrainte des types ne sont pas ajoutés.Note that primary keys and unique constraints are added to the ConstraintCollection according to the preceding rules, but other constraint types are not added.

Si un unique clustered index est défini sur une ou plusieurs colonnes dans une table SQL Server et la contrainte de clé primaire est définie sur un ensemble distinct de colonnes, les noms des colonnes dans l’index cluster seront retourné.If a unique clustered index is defined on a column or columns in a SQL Server table and the primary key constraint is defined on a separate set of columns, then the names of the columns in the clustered index will be returned. Pour renvoyer l’ou les noms des colonnes de clé primaire, utilisez un indicateur de requête avec l’instruction SELECT qui spécifie le nom de l’index de clé primaire.To return the name or names of the primary key columns, use a query hint with the SELECT statement that specifies the name of the primary key index. Pour plus d’informations sur la spécification des indicateurs de requête, consultez l’indicateur de requête (Transact-SQL).For more information about specifying query hints, see Query Hint (Transact-SQL).

Informations de clé primaire sont utilisées pendant Fill pour rechercher et remplacer les lignes dont les colonnes clés correspondent.Primary key information is used during Fill to find and replace any rows whose key columns match. Si ce n’est pas le comportement souhaité, utilisez Fill sans demander les informations de schéma.If this is not the desired behavior, use Fill without requesting schema information.

Si le IDataAdapter rencontre des colonnes dupliquées lors du remplissage un DataTable, il génère des noms pour les colonnes suivantes, selon le modèle »columnname1 », «columnname2 », »columnname3 » et ainsi de suite.If the IDataAdapter encounters duplicate columns while populating a DataTable, it generates names for the subsequent columns, using the pattern "columnname1", "columnname2", "columnname3", and so on. Si les données entrantes contiennent des colonnes sans nom, ils sont placés dans le DataSet selon le modèle « Column1 », « Column2 » et ainsi de suite.If the incoming data contains unnamed columns, they are placed in the DataSet according to the pattern "Column1", "Column2", and so on. Lorsque plusieurs jeux de résultats est ajoutés à la DataSet chaque jeu de résultats est placé dans une table distincte.When multiple result sets are added to the DataSet each result set is placed in a separate table. Jeux de résultats supplémentaires sont nommés en ajoutant des valeurs intégrales au nom de table spécifié (par exemple, « Table », « Table1 », « Table2 » et ainsi de suite.).Additional result sets are named by appending integral values to the specified table name (for example, "Table", "Table1", "Table2", and so on.). Applications à l’aide des noms de colonne et de table devraient vous assurer que tout conflit avec ces modèles d’affectation de noms ne se produit pas.Applications using column and table names should ensure that conflicts with these naming patterns does not occur.

Le IDbConnection objet associé à la commande select doit être valide, mais il est inutile d’ouvrir.The IDbConnection object associated with the select command must be valid, but it does not need to open. Si le IDbConnection est fermé avant FillSchema est appelée, elle est ouverte pour récupérer les données, puis fermé.If the IDbConnection is closed before FillSchema is called, it is opened to retrieve data, then closed. Si la connexion est ouverte avant FillSchema est appelée, il est laissé ouvert.If the connection is open before FillSchema is called, it is left open.

Notes

Lors du traitement d’instructions SQL par lots qui retournent plusieurs résultats, l’implémentation de FillSchema pour le fournisseur de données .NET Framework pour OLE DB récupère les informations de schéma pour seulement le premier résultat.When handling batch SQL statements that return multiple results, the implementation of FillSchema for the .NET Framework Data Provider for OLE DB retrieves schema information for only the first result. Pour récupérer les informations de schéma pour plusieurs résultats, utilisez Fill avec la MissingSchemaAction défini sur AddWithKey.To retrieve schema information for multiple results, use Fill with the MissingSchemaAction set to AddWithKey.

Lorsque vous utilisez FillSchema, le fournisseur de données .NET Framework pour SQL Server ajoute une clause FOR BROWSE à l’instruction en cours d’exécution.When using FillSchema, the .NET Framework Data Provider for SQL Server appends a FOR BROWSE clause to the statement being executed. L’utilisateur doit être conscient des effets secondaires potentiels, tels que les interférences avec l’utilisation d’instructions SET FMTONLY ON.The user should be aware of potential side effects, such as interference with the use of SET FMTONLY ON statements. Pour plus d’informations, consultez SET FMTONLY (Transact-SQL).For more information, see SET FMTONLY (Transact-SQL).

Voir aussi

S’applique à