Hypercell ein ] Hypercell aus ] Zeige Navigation ] Verstecke Navigation ]
c++.net  
   

Die mobilen Seiten von c++.net:
https://m.c-plusplus.net

  
C++ Forum :: MFC (Visual C++) ::  sql::Connection * per Pointer an Funktion übergeben     Zeige alle Beiträge auf einer Seite Auf Beitrag antworten
Autor Nachricht
Andi1234
Mitglied

Benutzerprofil
Anmeldungsdatum: 15.04.2018
Beiträge: 1
Beitrag Andi1234 Mitglied 10:32:15 15.04.2018   Titel:   sql::Connection * per Pointer an Funktion übergeben            Zitieren

Hallo zusammen,

ich möchte eine Funktion um eine Verbindung zu MySQL herzustellen.
Ziel ist es die Variable "con" per Pointer an die Funktion zu übergeben.

Folgende Fehlermeldung liefert mir der Compiler. Als IDE verwende ich VS2017.

Code:
Fehler  C4700   Die nicht initialisierte lokale Variable "con" wurde
verwendet.


Wie bekomme ich meine Vorstellung umgesetzt? ;)
Danke schonmal :)

C++:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
#include <cstdlib>
#include <stdio.h>
#include <iostream>

#include "mysql_connection.h"


#include <cppconn/driver.h>

#include <cppconn/exception.h>
#include <cppconn/resultset.h>
#include <cppconn/statement.h>

#ifdef __unix__

    #include <unistd.h>
#elif defined(_WIN32) || defined(WIN32)
    #include <windows.h>
    #define OS_Windows
#endif
 
using namespace std;
 
 
void mysql_verbinden(sql::Connection *con, std::string ip = "172.0.0.1") {
 
    sql::Driver *driver;
    try {
        /* Create a connection */
        driver = get_driver_instance();
        con = driver->connect("tcp://" + ip + ":3306", "root", "");
    }
    catch (sql::SQLException &e) {
        cout << "# ERR: SQLException in " << __FILE__;
        cout << "(" << __FUNCTION__ << ") on line " << __LINE__ << endl;
        cout << "# ERR: " << e.what();
        cout << " (MySQL error code: " << e.getErrorCode();
        cout << ", SQLState: " << e.getSQLState() << " )" << endl;
    }
    return;
}
 
 
int main(int argc, char** argv) {
   
    cout << endl;
    cout << "Running 'SELECT 'Hello World!' » AS _message'..." << endl;
 
    try {
        sql::Connection *con;
        sql::Statement *stmt;
        sql::ResultSet *res;
 
        // Verbindung aufbauen
        mysql_verbinden(con);
 
        stmt = con->createStatement();
        res = stmt->executeQuery("SELECT 'Hello World!' AS _message");
        while (res->next()) {
            cout << "\t... MySQL replies: ";
            /* Access column data by alias or column name */
            cout << res->getString("_message") << endl;
            cout << "\t... MySQL says it again: ";
            /* Access column data by numeric offset, 1 is the first column */
            cout << res->getString(1) << endl;
        }
        delete res;
        delete stmt;
        delete con;
 
    }
    catch (sql::SQLException &e) {
        cout << "# ERR: SQLException in " << __FILE__;
        cout << "(" << __FUNCTION__ << ") on line " << __LINE__ << endl;
        cout << "# ERR: " << e.what();
        cout << " (MySQL error code: " << e.getErrorCode();
        cout << ", SQLState: " << e.getSQLState() << " )" << endl;
    }
 
    cout << endl;
    boost::detail::Sleep(5000);
 
    return 0;
}
nullpointerx
Unregistrierter




Beitrag nullpointerx Unregistrierter 10:56:55 15.04.2018   Titel:              Zitieren

setz den pointer vorher auf null
Th69
Mitglied

Benutzerprofil
Anmeldungsdatum: 25.03.2008
Beiträge: 4946
Beitrag Th69 Mitglied 12:01:03 15.04.2018   Titel:              Zitieren

Das hilft auch nicht. Der Fehler ist, daß in der Funktion mysql_verbinden der Parameter nur als einfacher Zeiger (nicht als Doppelzeiger bzw. Referenz übergeben wird).
Besser wäre aber, den Zeiger als Rückgabewert der Funktion zu benutzen:
C++:
sql::Connection* mysql_verbinden(std::string ip = "172.0.0.1")
{
  sql::Connection *con;
  // ...
 
  return con;
}
Martin Richter
Moderator

Benutzerprofil
Anmeldungsdatum: 18.04.2006
Beiträge: 15422
Beitrag Martin Richter Moderator 07:56:29 16.04.2018   Titel:              Zitieren

Verwende eine Referenz.

C++:
void mysql_verbinden(sql::Connection* &con, std::string ip = "172.0.0.1") {

_________________
Martin Richter (MVP für C++ von 2000 bis 2015) WWJD http://blog.m-ri.de
"A well-written program is its own heaven; a poorly written program is its own hell!" The Tao of Programming


Zuletzt bearbeitet von Martin Richter am 10:47:34 16.04.2018, insgesamt 1-mal bearbeitet
C++ Forum :: MFC (Visual C++) ::  sql::Connection * per Pointer an Funktion übergeben   Auf Beitrag antworten

Zeige alle Beiträge auf einer Seite




Nächstes Thema anzeigen
Vorheriges Thema anzeigen
Sie können Beiträge in dieses Forum schreiben.
Sie können auf Beiträge in diesem Forum 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++.net 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 und www.c-plusplus.net 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.