• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

question-closed MySql c++ connect błąd

Object Storage Arubacloud
0 głosów
216 wizyt
pytanie zadane 15 lutego 2023 w C i C++ przez piotr_domanski Bywalec (2,080 p.)
zamknięte 16 lutego 2023 przez piotr_domanski

Witam, napisałem program łączący się z MySQL,

Program pyta się użytkownika o nazwę i hasło i potem jest to wpisywane do bazy danych. Program się kompiluje ale w konsoli jest błąd o numerze: 

O co chodzi ?

KOD:

#include <iostream>
#include <Windows.h>
#include <mysql.h>
#include <iomanip>
#include <stdlib.h>
#include <sstream>
#include <stdio.h>

using namespace std;

int main()
{
    MYSQL* conn;
    MYSQL_ROW row;
    MYSQL_RES * res;

    int qstate;

    conn = mysql_init(0);
    conn = mysql_real_connect(conn, "localhost", "login_user", "123", "mathtoolmysql", 0, NULL, 0);

    if(conn)
    {
        cout <<" Connection to database successful:"<<endl;

        string f_name, l_name, username, password;

        cout <<" Enter your first name"<<endl;
        cin >> f_name;

        cout <<" Enter last name"<<endl;
        cin >> l_name;

        cout <<" Enter username"<<endl;
        cin >> username;

        cout<<" Enter password:"<<endl;
        cin>> password;


        stringstream ss;

        ss << " INSERT INTO registration (First_Name, Last_Name, Username, Password) values ('" << f_name<<"','" << l_name<<" ','" <<username<<" ','" <<password <<"')";

        string query = ss.str ();
        const char * q = query.c_str();
        qstate = mysql_query(conn, q);

        if (qstate == 0)
        {

            cout <<" Record inserted successfully ..."<<endl;
        }
        else
        {
            cout <<" Error, data not inserted..."<<endl;
        }
    }

    if (conn)
    {
        qstate = mysql_query(conn, "SELECT * FROM logowanie");

        if (!qstate)
        {
            res = mysql_store_result(conn);


            while (row = mysql_fetch_row (res))
            {



                cout<<" ID : "<< row [0]<<endl;
                cout <<" First name: "<<row [1]<<endl;
                cout <<" Last name: "<< row [2]<<endl;
                cout <<" Username: " <<row [3] <<endl;
            }
        }
    }

    else
    {
        cout <<" Connection failure"<<endl;
    }

    return 0;
}

 

komentarz zamknięcia: rozwiązanie

1 odpowiedź

+2 głosów
odpowiedź 15 lutego 2023 przez tangarr Mędrzec (154,860 p.)

Podejrzewam, że mysql_init próbuje załadować plik dll z biblioteką ale to się nie udaje.

Spróbuj na początku programu dodać kod

if (mysql_library_init(0, NULL, NULL)) {
    fprintf(stderr, "could not initialize MySQL client library\n");
    exit(1);
  }

Jeżeli po uruchomieniu programu zobaczysz ten komunikat to prawdopodobnie plik dll znajduje się w złym miejscu. Znajdź katalog w którym budowany jest twój program i skopiuj do niego plik dll.

Podobne pytania

0 głosów
1 odpowiedź 787 wizyt
0 głosów
0 odpowiedzi 259 wizyt

92,568 zapytań

141,422 odpowiedzi

319,637 komentarzy

61,957 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...