MsiDatabaseOpenViewA, fonction (msiquery.h)
La fonction MsiDatabaseOpenView prépare une requête de base de données et crée un objet de vue. Cette fonction retourne un handle qui doit être fermé à l’aide de MsiCloseHandle.
Syntaxe
UINT MsiDatabaseOpenViewA(
[in] MSIHANDLE hDatabase,
[in] LPCSTR szQuery,
[out] MSIHANDLE *phView
);
Paramètres
[in] hDatabase
Gérez la base de données à laquelle vous souhaitez ouvrir un objet d’affichage. Vous pouvez obtenir le handle comme décrit dans Obtention d’un handle de base de données.
[in] szQuery
Spécifie une chaîne de requête SQL pour interroger la base de données. Pour une syntaxe correcte, consultez Syntaxe SQL.
[out] phView
Pointeur vers un handle pour la vue retournée.
Valeur retournée
La fonction MsiDatabaseOpenView retourne l’une des valeurs suivantes :
ERROR_SUCCESS en cas de réussite, et le handle d’affichage vers lequel pointe le paramètre phView [out] est défini.
ERROR_INVALID_HANDLE, ERROR_INVALID_HANDLE_STATE, ERROR_BAD_QUERY_SYNTAX ou ERROR_GEN_FAILURE en cas d’échec, et définit l’enregistrement d’erreur, accessible via MsiGetLastErrorRecord.
Remarques
La fonction MsiDatabaseOpenView ouvre un objet view pour une base de données. Vous devez ouvrir un objet de vue pour une base de données avant d’effectuer une exécution ou une extraction.
Si une erreur se produit, vous pouvez appeler MsiGetLastErrorRecord pour plus d’informations.
Notez qu’il est recommandé d’utiliser des variables de type PMSIHANDLE, car le programme d’installation ferme les objets PMSIHANDLE en dehors de leur portée, tandis que vous devez fermer les objets MSIHANDLE en appelant MsiCloseHandle. Pour plus d’informations, consultez la section Utiliser PMSIHANDLE au lieu de HANDLE dans les Bonnes pratiques de Windows Installer.
Si la fonction échoue, vous pouvez obtenir des informations d’erreur étendues à l’aide de MsiGetLastErrorRecord.
Notes
L’en-tête msiquery.h définit MsiDatabaseOpenView comme alias qui sélectionne automatiquement la version ANSI ou Unicode de cette fonction en fonction de la définition de la constante de préprocesseur UNICODE. La combinaison de l’utilisation de l’alias neutre en encodage avec du code qui n’est pas neutre en encodage peut entraîner des incompatibilités qui entraînent des erreurs de compilation ou d’exécution. Pour plus d’informations, consultez Conventions pour les prototypes de fonction.
Configuration requise
Condition requise | Valeur |
---|---|
Client minimal pris en charge | Windows Installer 5.0 sur Windows Server 2012, Windows 8, Windows Server 2008 R2 ou Windows 7. Windows Installer 4.0 ou Windows Installer 4.5 sur Windows Server 2008 ou Windows Vista. Windows Installer sur Windows Server 2003 ou Windows XP |
Plateforme cible | Windows |
En-tête | msiquery.h |
Bibliothèque | Msi.lib |
DLL | Msi.dll |