Partager via


Objets OLE DB utilisés par les requêtes distribuées

Le tableau ci-dessous répertorie les objets et les interfaces OLE DB qui sont utilisés par les requêtes distribuées Transact-SQL. Un fournisseur OLE DB doit au moins prendre en charge un ensemble minimal de ces objets et interfaces pour pouvoir être utilisé dans des requêtes distribuées Transact-SQL. Ces objets et interfaces comportent un Oui dans la colonne Requis du tableau. Les objets et les interfaces affectés de la valeur Non dans la colonne Requis sont requis uniquement pour prendre en charge les fonctionnalités avancées des requêtes distribuées. Si l'interface n'est pas prise en charge par le fournisseur, la fonctionnalité Transact-SQL correspondante ne l'est pas non plus. Par exemple, si les interfaces IRowsetLocate et IRowsetChange ne sont pas prises en charge, les instructions UPDATE et DELETE ne fonctionnent pas sur les tables distantes.

Objet

Interface

Obligatoire

Description

Data Source

IDBInitialize

Oui

Initialise et configure les données et le contexte de sécurité.

 

IDBCreateSession

Oui

Crée un objet DB Session.

 

IDBProperties

Oui

Permet d'obtenir des informations sur les fonctions d'un fournisseur et de définir des propriétés d'initialisation.

 

IDBInfo

Non

Permet d'obtenir des informations sur la syntaxe SQL prise en charge par le fournisseur.

DB Session

IDBSchemaRowset

Non

Permet d'obtenir des métadonnées sur les tables et les colonnes. Les ensembles de lignes requis sont TABLES et COLUMNS. Les autres ensembles de lignes utilisés, s'ils sont disponibles, sont TABLES_INFO, CATALOGS, INDEXES, STATISTICS, TABLE_STATISTICS, VIEWS, PRIMARY_KEYS, TABLE_PRIVILEGES et COLUMN_PRIVILEGES.

 

IOpenRowset

Oui

Ouvre un ensemble de lignes sur une table, un index ou un histogramme.

 

IGetDataSource

Oui

Permet de revenir à l'objet source de données à partir d'un objet DB Session.

 

IDBCreateCommand

Non

Crée un objet Command (requête).

 

ITransactionLocal

Non

Démarre une transaction sur le fournisseur.

 

ITransactionJoin

Non

Cette interface permet de prendre en charge les transactions distribuées. Si elle n'est pas prise en charge, il n'est pas possible d'effectuer de mise à jour sur un fournisseur distant dans une transaction utilisateur.

Rowset (sur une table)

IRowset

Oui

Analyse les lignes.

 

IAccessor

Oui

Établit des liaisons avec des colonnes d'un ensemble de lignes.

 

IColumnsInfo

Oui

Permet d'obtenir des informations sur les colonnes d'un ensemble de lignes.

 

IRowsetInfo

Oui

Permet d'obtenir des informations sur les propriétés d'un ensemble de lignes.

 

IRowsetLocate

Non

Obligatoire pour les opérations UPDATE ou DELETE et les recherches basées sur les index.

 

IRowsetChange

Non

Obligatoire pour les opérations INSERT, UPDATE et DELETE sur une table. Les ensembles de lignes des tables de base doivent être compatibles avec cette interface pour pouvoir prendre en charge les instructions INSERT, UPDATE et DELETE.

 

IConvertType

Oui

Vérifie si un ensemble de lignes prend en charge des conversions de types de données spécifiques sur ses colonnes.

Rowset (sur un index)

IRowset

Oui

Analyse les lignes.

 

IAccessor

Oui

Établit des liaisons avec des colonnes d'un ensemble de lignes.

 

IColumnsInfo

Oui

Permet d'obtenir des informations sur les colonnes d'un ensemble de lignes.

 

IRowsetInfo

Oui

Permet d'obtenir des informations sur les propriétés d'un ensemble de lignes.

 

IRowsetIndex

Oui

Obligatoire pour les ensembles de lignes d'un index ; utilisée avec la fonctionnalité d'indexation (définition de plages, recherche).

 

IConvertType

Oui

Vérifie si l'ensemble de lignes prend en charge les conversions de types de données spécifiques sur ses colonnes.

Command (facultatif)

ICommand

Oui

Permet d'exécuter des requêtes.

 

ICommandText

Oui

Permet de définir le texte de la requête.

 

ICommandProperties

Oui

Permet de spécifier les propriétés requises sur des ensembles de lignes retournés par la commande.

 

ICommandWithParameters

Non

Utilisé pour exécuter des requêtes paramétrées.

 

ICommandPrepare

Non

Utilisé pour préparer une commande permettant d'obtenir des métadonnées.

Error (facultatif)

IErrorRecords

Oui

Permet de définir un pointeur sur une interface IErrorInfo pour un enregistrement d'erreur.

 

IErrorInfo

Oui

Permet d'obtenir une description (texte) d'un enregistrement d'erreur.

Any object (facultatif)

ISupportErrorInfo

Non

Détermine si une interface spécifiée prend en charge les objets erreur.