Hypercell ein ] Hypercell aus ] Zeige Navigation ] Verstecke Navigation ]
c++.de  
   
Forentreff 2012     
Bücher-Shop mit Amazon (Buchkategorien)C++ : Referenzen zu C++ : C++ Builder : Visual C++ : C# : Java : Spieleprogrammierung : Systemprogrammierung Linux : Software-Entwicklung : .NET : Compilertechnik : Algorithmen & Datenstrukturen : Objektorientierung : Entwurfsmuster : UML : eXtreme Programming : Scrum : Projektmanagement : Software-Testing : Datenbanken : Tom DeMarco : Dilbert : User Friendly
C/C++ Forum :: FAQ - MFC ::  Datenbank - Auflistung aller ODBCs in einer Combox     Zeige alle Beiträge auf einer Seite Auf Beitrag antworten
Autor Nachricht
Penny
Unregistrierter




Beitrag Penny Unregistrierter 12:30:00 19.07.2002   Titel:   Datenbank - Auflistung aller ODBCs in einer Combox            Zitieren

hab folgendes problemchen:
brauche eine auswahl aller, auf dem jeweiligen rechner installierten, ODBC-Datenquellen-> sprich der user soll in einem dialog, und dort in einer combobox, alle auf seinem system installierten ODBCs sehen und eine auswählen können (quasi wie beim ODBC-Administrator...)!
wär super wenn mir jemand weiterhelfen könnte.
bei der gelegenheit:
ein dreifaches hoch auf die MSDN - selten so eine übersichtliche Hilfe zu Gesicht bekommen...


Zuletzt bearbeitet von estartu am 12:41:39 16.01.2006, insgesamt 1-mal bearbeitet
Werbeunterbrechung
MacReeg
Mitglied

Benutzerprofil
Anmeldungsdatum: 22.05.2002
Beiträge: 153
Beitrag MacReeg Mitglied 13:45:00 19.07.2002   Titel:              Zitieren

Hallo Penny !

Folgender Programmschnipsel sollte Dein Problem eigentlich lösen:

Code:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
    SQLHENV m_henv;         // Environmenthandle für SQL-API
   
    // Initialisieren der ODBC-Umgebung zum Auslesen

    ::SQLAllocHandle(SQL_HANDLE_ENV, SQL_NULL_HANDLE, &m_henv);
    ::SQLSetEnvAttr(m_henv, SQL_ATTR_ODBC_VERSION, (SQLPOINTER) SQL_OV_ODBC3, SQL_IS_INTEGER);
    ::SQLAllocEnv(&m_henv);
   
    // Auslesen der ODBC-Quellen und Anzeigen in ComboBox

    UCHAR NameDSN[SQL_MAX_DSN_LENGTH + 1];
    UCHAR InfoDSN[512];

    SWORD InfoLen, DSNLen;

    // Ein Element aus der ODBC-Quellenliste auslesen

    while (::SQLDataSources(m_henv, SQL_FETCH_NEXT, NameDSN, sizeof(NameDSN), &DSNLen,
                             InfoDSN, sizeof(InfoDSN), &InfoLen) != SQL_NO_DATA_FOUND)
    {
        // Einfügen des ausgelesenen Elementes in die ComboBox

        m_Liste.AddString(CString(NameDSN));
    }
Code:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
SQLHENV m_henv; // Environmenthandle für SQL-API

// Initialisieren der ODBC-Umgebung zum Auslesen

::SQLAllocHandle(SQL_HANDLE_ENV, SQL_NULL_HANDLE, &m_henv);
::SQLSetEnvAttr(m_henv, SQL_ATTR_ODBC_VERSION, (SQLPOINTER) SQL_OV_ODBC3, SQL_IS_INTEGER);
::SQLAllocEnv(&m_henv);

// Auslesen der ODBC-Quellen und Anzeigen in ComboBox

UCHAR NameDSN[SQL_MAX_DSN_LENGTH + 1];
UCHAR InfoDSN[512];

SWORD InfoLen, DSNLen;

// Ein Element aus der ODBC-Quellenliste auslesen

while (::SQLDataSources(m_henv, SQL_FETCH_NEXT, NameDSN, sizeof(NameDSN), &DSNLen,
InfoDSN, sizeof(InfoDSN), &InfoLen) != SQL_NO_DATA_FOUND)
{
// Einfügen des ausgelesenen Elementes in die ComboBox

m_Liste.AddString(CString(NameDSN));
}
Code:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
    SQLHENV m_henv;         // Environmenthandle für SQL-API
   
    // Initialisieren der ODBC-Umgebung zum Auslesen

    ::SQLAllocHandle(SQL_HANDLE_ENV, SQL_NULL_HANDLE, &m_henv);
    ::SQLSetEnvAttr(m_henv, SQL_ATTR_ODBC_VERSION, (SQLPOINTER) SQL_OV_ODBC3, SQL_IS_INTEGER);
    ::SQLAllocEnv(&m_henv);
   
    // Auslesen der ODBC-Quellen und Anzeigen in ComboBox

    UCHAR NameDSN[SQL_MAX_DSN_LENGTH + 1];
    UCHAR InfoDSN[512];

    SWORD InfoLen, DSNLen;

    // Ein Element aus der ODBC-Quellenliste auslesen

    while (::SQLDataSources(m_henv, SQL_FETCH_NEXT, NameDSN, sizeof(NameDSN), &DSNLen,
                             InfoDSN, sizeof(InfoDSN), &InfoLen) != SQL_NO_DATA_FOUND)
    {
        // Einfügen des ausgelesenen Elementes in die ComboBox

        m_Liste.AddString(CString(NameDSN));
    }


Dieser Source trägt sämtliche ODBC-Datenquellen (DBase-Dateien, Excel-Datein usw.) in eine ComboBox (m_Liste) ein. Um das Programm laufen zu lassen, musst Du noch in der stdafx.h folgenden #include einfügen:

Code:
#include <afxdb.h>        // MFC-Datenbankunterstützung
Code:
#include <afxdb.h> // MFC-Datenbankunterstützung
Code:
#include <afxdb.h>        // MFC-Datenbankunterstützung


Gruß MacReeg

[ Dieser Beitrag wurde am 19.07.2002 um 14:24 Uhr von MacReeg editiert. ]

_________________
eMail: info@inc-x.de
Internet: www.inc-x.de


Zuletzt bearbeitet von MacReeg am 22:48:46 16.02.2004, insgesamt 2-mal bearbeitet
Penny
Unregistrierter




Beitrag Penny Unregistrierter 17:46:00 21.07.2002   Titel:              Zitieren

Hi MacReeg,
Super !
Vielen Dank ! - läuft wunderbar !!
C/C++ Forum :: FAQ - MFC ::  Datenbank - Auflistung aller ODBCs in einer Combox   Auf Beitrag antworten

Zeige alle Beiträge auf einer Seite




Nächstes Thema anzeigen
Vorheriges Thema anzeigen
Sie können keine Beiträge in dieses Forum schreiben.
Sie können auf Beiträge in diesem Forum nicht antworten.
Sie können Ihre Beiträge in diesem Forum nicht bearbeiten.
Sie können Ihre Beiträge in diesem Forum nicht löschen.
Sie können an Umfragen in diesem Forum nicht mitmachen.

Powered by phpBB © 2001, 2002 phpBB Group :: FI Theme

c++.de ist Teilnehmer des Partnerprogramms von Amazon Europe S.à.r.l. und Partner des Werbeprogramms, das zur Bereitstellung eines Mediums für Websites konzipiert wurde, mittels dessen durch die Platzierung von Werbeanzeigen und Links zu amazon.de Werbekostenerstattung verdient werden kann.

Die Vervielfältigung der auf den Seiten www.c-plusplus.de, www.c-plusplus.info, www.c-sar.de, www.c-plusplus.net und www.baeckmann.de enthaltenen Informationen ohne eine schriftliche Genehmigung des Seitenbetreibers ist untersagt (vgl. §4 Urheberrechtsgesetz). Die Nutzung und Änderung der vorgestellten Strukturen und Verfahren in privaten und kommerziellen Softwareanwendungen ist ausdrücklich erlaubt, soweit keine Rechte Dritter verletzt werden. Der Seitenbetreiber übernimmt keine Gewähr für die Funktion einzelner Beiträge oder Programmfragmente, insbesondere übernimmt er keine Haftung für eventuelle aus dem Gebrauch entstehenden Folgeschäden.