Partager via


TN055 : Migration des applications de classe de base de données ODBC MFC vers des classes DAO MFC

Remarque

DAO est utilisé avec les bases de données Access et est pris en charge via Bureau 2013. DAO 3.6 est la version finale, et elle est considérée comme obsolète. L’environnement et les Assistants Visual C++ ne prennent pas en charge DAO (bien que les classes DAO soient incluses et que vous pouvez toujours les utiliser). Microsoft vous recommande d’utiliser des modèles OLE DB ou ODBC et MFC pour de nouveaux projets. Vous devez uniquement utiliser DAO pour gérer les applications existantes.

Vue d’ensemble

Dans de nombreux cas, il peut être souhaitable de migrer les applications qui utilisent les classes de la base de données ODBC de MFC vers les classes de bases de données DAO de MFC. Cette note technique détaillera la plupart des différences entre les classes ODBC et DAO de MFC. Avec les différences à l'esprit, il ne doit pas être très difficile de migrer des applications depuis les classes ODBC vers les classes de MFC si vous le souhaitez.

Pourquoi migrer d’ODBC vers DAO

Il y a plusieurs raisons pour lesquelles vous pouvez migrer des applications depuis les classes de base de données ODBC vers les classes de base de données DAO, mais la décision n'est pas nécessairement simple ou évidente. Une chose à prendre en compte est le fait que le moteur de base de données Microsoft Jet utilisé par DAO peut indiquer une source de données ODBC pour laquelle vous avez un pilote ODBC. Il peut être plus efficace d'utiliser les classes de base de données ODBC ou d'appeler vous-même ODBC directement, mais le moteur de base de données Microsoft Jet peut lire des données ODBC.

Il existe certains cas simples qui facilitent la prise de décision ODBC/DAO. Par exemple, lorsque vous avez besoin d'accéder uniquement aux données dans un format que le moteur Microsoft Jet peut lire directement (formats Access, Excel, etc.), il devient évident de choisir l'utilisation des classes de base de données DAO.

Des cas complexes se présentent si vos données sont disponibles sur un serveur ou plusieurs serveurs. Dans ce cas, la décision d'utiliser les classes de base de données ODBC ou les classes de base de données DAO est difficile. Si vous souhaitez effectuer des opérations telles que les jointures hétérogènes (joindre des données depuis des serveurs dans plusieurs formats comme SQL Server et Oracle), le moteur de base de données Microsoft Jet effectue la jointure pour vous plutôt que de vous forcer à effectuer le travail nécessaire si vous utilisiez les classes de base de données ODBC ou si vous appeliez ODBC directement. Si vous utilisez un pilote ODBC qui prend en charge les curseurs de pilote, le meilleur choix pourrait bien être les classes de base de données ODBC.

Le choix peut être compliqué, c'est pourquoi vous pouvez entrer plusieurs exemples de code pour tester les performances des différentes méthodes données en fonction de vos besoins particuliers. Cette note technique suppose que vous avez pris la décision de migrer des classes de base de données ODBC vers des classes de base de données DAO.

Similitudes entre les classes de base de données ODBC et les classes de base de données DAO MFC

La conception d'origine des classes ODBC MFC est basée sur le modèle d'objet DAO qui a été utilisé dans Microsoft Access et Microsoft Visual Basic. Cela signifie qu’il existe de nombreuses fonctionnalités communes aux classes ODBC et DAO MFC, qui ne seront pas toutes répertoriées dans cette section. En général, les modèles de programmation sont les mêmes.

Pour mettre en évidence les similitudes :

  • Les classes ODBC et DAO disposent d'objets de base de données qui gèrent l'utilisation du système de gestion de base de données sous-jacent (SGBD).

  • Les deux classes ont des objets de jeux d'enregistrements qui représentent un ensemble de résultats issus de ce système SGBD.

  • Les objets de la base de données DAO et les objets des jeux d'enregistrements sont des membres quasiment identiques aux classes ODBC.

  • Dans les deux jeux de classes, le code permettant d'extraire les données est identique sauf pour certaines modifications d'objet et de nom de membre. Les modifications sont nécessaires, mais généralement le processus est un changement de nom simple lorsque vous passez des classes ODBC aux classes DAO.

Par exemple, dans les deux modèles, la procédure pour récupérer des données consiste à créer et ouvrir un objet de base de données, à créer et ouvrir un objet de jeu d'enregistrements et à naviguer (se déplacer) entre les données en effectuant certaines opérations.

Différences entre les classes ODBC et DAO de MFC

Les classes DAO incluent plus d'objets et un ensemble plus riche de méthodes, mais cette section détaillera uniquement les différences dans les classes et les fonctionnalités similaires.

Les différences les plus évidentes entre les classes sont probablement les changements de nom pour les classes semblables et les fonctions globales. La liste suivante présente les changements de nom des objets, des méthodes et des fonctions globales associés aux classes de base de données :

Classe ou fonction Équivalence dans les classes DAO MFC
CDatabase CDaoDatabase
CDatabase::ExecuteSQL CDaoDatabase::Execute
CRecordset CDaoRecordset
CRecordset::GetDefaultConnect CDaoRecordset::GetDefaultDBName
CFieldExchange CDaoFieldExchange
RFX_Bool DFX_Bool
RFX_Byte DFX_Byte
RFX_Int DFX_Short
RFX_Long DFX_Long
DFX_Currency
RFX_Single DFX_Single
RFX_Double DFX_Double
RFX_Date1 DFX_Date (COleDateTimebasé)
RFX_Text DFX_Text
RFX_Binary DFX_Binary
RFX_LongBinary DFX_LongBinary

1 La RFX_Date fonction est basée sur CTime et TIMESTAMP_STRUCT.

Les principales modifications apportées aux fonctionnalités qui peuvent affecter votre application et qui requièrent plus que de simples changements de nom sont répertoriées ci-dessous.

  • Les constantes et les macros permettant de spécifier que des éléments comme le type ouvert de jeu d'enregistrements et les options ouvertes de jeu d'enregistrements ont été modifiées.

    Avec les classes ODBC, MFC avait besoin de définir ces options via des macros ou des types énumérés.

    Avec les classes DAO, DAO fournit la définition de ces options dans un fichier d'en-tête (DBDAOINT.H). Ce type d'ensemble d'enregistrements est un membre énuméré de CRecordset, mais avec DAO il s'agit en fait d'une constante. Par exemple, vous utilisez instantané lors de la spécification du type dans CRecordset ODBC, mais DB_OPEN_SNAPSHOT lors de la spécification du type de CDaoRecordset.

  • Le type de jeu d’enregistrements par défaut pour CRecordset lequel il est instantané tandis que le type de jeu d’enregistrements par défaut pour CDaoRecordset lequel il s’agit d’un jeu de données dynamique (voir la remarque ci-dessous pour un problème supplémentaire sur les instantané s de classe ODBC).

  • La classe ODBC CRecordset comporte une option permettant de créer un type de jeu d'enregistrements basé sur le transfert uniquement. Dans la classe CDaoRecordset, le transfert uniquement n'est pas un type de jeu d'enregistrements, mais plutôt une propriété (ou option) de certains types de jeux d'enregistrements.

  • Un jeu d'enregistrements basé sur l'ajout uniquement lors de l'ouverture d'un objet CRecordset signifiait que les données du jeu d'enregistrements pouvaient être lues et ajoutées. Avec l'objet CDaoRecordset, l'option d'ajout uniquement signifie littéralement que les données du jeu d'enregistrements peuvent être ajoutées (et non lues).

  • Les fonctions membres de la transaction des classes ODBC sont membres de CDatabase et agissent au niveau de la base de données. Dans les classes DAO, les fonctions membres de transaction sont membres d’une classe de niveau supérieur (CDaoWorkspace) et peuvent avoir un impact sur plusieurs objets CDaoDatabase qui partagent le même espace de travail (espace de transaction).

  • La classe d'exception a été modifiée. CDBExceptions sont levées dans les classes ODBC et CDaoExceptions dans les classes DAO.

  • RFX_Date utilise CTime et TIMESTAMP_STRUCT les objets lors de l’utilisation DFX_Date COleDateTime. La COleDateTime valeur est presque identique à CTime, mais est basée sur un OLE DATE de 8 octets plutôt qu’un time_t de 4 octets afin qu’il puisse contenir une plus grande plage de données.

    Remarque

    Les instantanés (CDaoRecordset) DAO sont en lecture seule alors que les instantanés (CRecordset) ODBC peuvent être modifiés selon le pilote et l'utilisation de la bibliothèque de curseurs ODBC. Si vous utilisez la bibliothèque de curseurs, les instantanés CRecordset sont modifiables. Si vous utilisez des pilotes Microsoft issus de Desktop Driver Pack 3.0 sans bibliothèque de curseurs ODBC, les instantanés CRecordset sont en lecture seule. Si vous utilisez un autre pilote, case activée la documentation du pilote pour voir si les instantané (STATIC_CURSORS) sont en lecture seule.

Voir aussi

Notes techniques par numéro
Notes techniques par catégorie