IDataAdapter.FillSchema(DataSet, SchemaType) IDataAdapter.FillSchema(DataSet, SchemaType) IDataAdapter.FillSchema(DataSet, SchemaType) Method

Définition

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:
 cli::array <System::Data::DataTable ^> ^ FillSchema(System::Data::DataSet ^ dataSet, System::Data::SchemaType schemaType);
public System.Data.DataTable[] FillSchema (System.Data.DataSet dataSet, System.Data.SchemaType schemaType);
abstract member FillSchema : System.Data.DataSet * System.Data.SchemaType -> 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.

Retours

Tableau d'objets DataTable qui contient les 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 DataTable et 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 toutes les colonnes uniques sont non nullable.If no primary key columns are returned but unique columns are, the unique columns are used as the primary key if all the unique columns are non-nullable. 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 previous 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 façon de spécifier des indicateurs de requête, consultez l’indicateur de requête (Transact-SQL).For more information about how to specify query hints, see Query Hint (Transact-SQL).

Si le IDataAdapter rencontre des colonnes dupliquées lors du remplissage d’un DataTable, il génère des noms pour les colonnes successives, à l’aide du modèle « columnname1 », « columnname2 », « columnname3 » et ainsi de suite.If the IDataAdapter encounters duplicate columns while populating a DataTable, it generates names for the successive columns, using the pattern "columnname1", "columnname2", "columnname3", and so on. Si les données entrantes contiennent des colonnes sans nom, ils sont placés le DataSet selon le modèle « Column1 », « Column2 » et ainsi de suite.If the incoming data contains unnamed columns, they are put 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 put 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 soyez prudent lorsque vous utilisez des noms de colonne et de table afin d’éviter tout conflit avec ces modèles d’affectation de noms.Applications should use caution when using column and table names to ensure that conflicts with these naming patterns do not occur.

FillSchema ne retourne aucune ligne.FillSchema returns no rows. Utilisez le Fill méthode pour ajouter des lignes à un DataTable.Use the Fill method to add rows to a DataTable.

S’applique à

Voir aussi