abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    včera 19:44 | IT novinky

    Microsoft představil Azure Linux 4.0 a Azure Container Linux. Na konferenci Open Source Summit North America 2026 organizované konsorciem Linux Foundation a sponzorované také Microsoftem. Azure Linux 4.0 vychází z Fedora Linuxu. Azure Container Linux je založen na projektu Flatcar. Azure Linux (GitHub, Wikipedie) byl původně znám jako CBL-Mariner.

    Ladislav Hagara | Komentářů: 0
    včera 12:22 | Zajímavý článek

    Nové číslo časopisu Raspberry Pi zdarma ke čtení: Raspberry Pi Official Magazine 165 (pdf).

    Ladislav Hagara | Komentářů: 0
    včera 10:55 | Nová verze

    Byla vydána verze 9.2 open source virtualizační platformy Proxmox VE (Proxmox Virtual Environment, Wikipedie) založené na Debianu. Přehled novinek v poznámkách k vydání a informačním videu.

    Ladislav Hagara | Komentářů: 4
    včera 09:33 | IT novinky

    Firefox 151 podporuje Web Serial API. Pro komunikaci s různými mikrokontroléry připojenými přes USB nebo sériové porty už není nutné spouštět Chrome nebo na Chromiu postavené webové prohlížeče.

    Ladislav Hagara | Komentářů: 4
    včera 04:44 | Nová verze

    Byla vydána nová stabilní verze 8.0 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 148. Přehled novinek i s náhledy v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    21.5. 21:33 | Bezpečnostní upozornění

    Ve FreeBSD byla nalezena a opravena zranitelnost FatGid aneb CVE-2026-45250. Jedná se o lokální eskalaci práv. Neprivilegovaný uživatel se může stát rootem.

    Ladislav Hagara | Komentářů: 0
    21.5. 14:33 | IT novinky

    Společnost Flipper Devices oznámila Flipper One. Zcela nový Flipper postavený od nuly. Jedná se o open-source linuxovou platformu založenou na čipu Rockchip RK3576. Hledají se dobrovolníci pro pomoc s dokončením vývoje (ovladače, testování, tvorba modulů).

    Ladislav Hagara | Komentářů: 2
    21.5. 14:00 | Nová verze

    Vývojáři Wine oznámili vydání verze 2.0 knihovny vkd3d pro překlad volání Direct3D na Vulkan. Přehled novinek na GitLabu.

    Ladislav Hagara | Komentářů: 0
    21.5. 11:33 | Nová verze

    Společnost Red Hat oznámila vydání Red Hat Enterprise Linuxu (RHEL) 10.2 a 9.8. Vedle nových vlastností a oprav chyb přináší také aktualizaci ovladačů a předběžné ukázky budoucích technologií. Vypíchnout lze CLI AI asistenta goose. Podrobnosti v poznámkách k vydání (10.2 a 9.8).

    Ladislav Hagara | Komentářů: 0
    21.5. 05:11 | Nová verze

    Organizace Apache Software Foundation (ASF) vydala verzi 30 integrovaného vývojového prostředí a vývojové platformy napsané v Javě NetBeans (Wikipedie). Přehled novinek na GitHubu. Instalovat lze také ze Snapcraftu a Flathubu.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (12%)
     (8%)
     (2%)
     (14%)
     (31%)
     (4%)
     (6%)
     (3%)
     (16%)
     (26%)
    Celkem 1685 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník

    Dotaz: C++ && MySQL

    25.3.2008 12:38 martin.developer | blog: void | Zlín
    C++ && MySQL
    Přečteno: 4184×
    Dobrý den.

    S C++ vpodstatě začínám a chci si udělat program(konzolová aplikace), který vytáhne data z mysql a vypíše je.
    Na tuto věc jsem zkoušel už MySQL++ ale vpodstatě bych řekl že je to až moc složitý pro takové blbinky.
    Chci se zeptat jestli nevíte o nečem jednoduším.
    Prostě aby se to dalo napsat podobně jako v PHP( mysql_connect() mysql_query()... ).
    Slyšel jsem někdo něco o libmysqlclient ale nevím co to je a kde to sehnat.

    Děkuju za všecny rady.
    Pamatujte si, kde jste byli, když jste Vy začínali. To změní Váš pohled na lidi, jenž začínají teď!

    Odpovědi

    Diskuse byla administrátory uzamčena.
    FAQ: Proč byl uzamčen/smazán můj dotaz v Poradně?

    25.3.2008 12:46 miro | skóre: 19 | blog: miro
    Rozbalit Rozbalit vše Re: C++ && MySQL
    Priamo s MySQL je dodavane ceckove API, MySQL++ je len jeho objektovou nadstavbou. Skus pozriet MySQL C API, mozno to je to co hladas.
    25.3.2008 13:21 martin.developer | blog: void | Zlín
    Rozbalit Rozbalit vše Re: C++ && MySQL
    Tak jsem to zkusil( děkuju moc za to MYSQL C API ), ale dostal jsem pár chybových hlášení.

    Chyby:
    Compiling...
    main.cpp
    c:\program files\mysql\mysql server 5.0\include\mysql_com.h(183) : error C2146: syntax error : missing ';' before identifier 'fd'
    c:\program files\mysql\mysql server 5.0\include\mysql_com.h(183) : error C4430: missing type specifier - int assumed. Note: C++ does not support default-int
    c:\program files\mysql\mysql server 5.0\include\mysql_com.h(183) : error C4430: missing type specifier - int assumed. Note: C++ does not support default-int
    c:\program files\mysql\mysql server 5.0\include\mysql_com.h(358) : error C2065: 'SOCKET' : undeclared identifier
    c:\program files\mysql\mysql server 5.0\include\mysql_com.h(358) : error C2146: syntax error : missing ')' before identifier 's'
    c:\program files\mysql\mysql server 5.0\include\mysql_com.h(359) : error C2059: syntax error : ')'
    c:\documents and settings\martin\dokumenty\visual studio 2008\projects\vyuka\procvicovani\main.cpp(15) : error C2146: syntax error : missing ';' before identifier 'res'
    c:\documents and settings\martin\dokumenty\visual studio 2008\projects\vyuka\procvicovani\main.cpp(18) : warning C4018: '<' : signed/unsigned mismatch

    Kód:
    #include <stdio.h>
    #include <mysql/mysql.h>
    #include <string.h>

    int main()
    {
    int i = 1;
    MYSQL mysql;
    MYSQL_RES *res;
    MYSQL_ROW row;
    char *query="SELECT * FROM user";
    mysql_init(&mysql);
    mysql_real_connect(&mysql,"localhost","root","6g8j2","test",0,NULL,0);
    mysql_real_query(&mysql,query,(unsigned int) strlen(query))
    res=mysql_store_result(&mysql);
    printf("Pocet sloupcu %d, pocet radku: %d \n",mysql_num_fields(res),mysql_num_rows(res));
    while(row=mysql_fetch_row(res)) {
    for(i=0;i<mysql_num_fields(res);i++) printf(row[i]);
    putchar('\n');
    }
    mysql_free_result(res);
    mysql_close(&mysql);
    mysql_close(&mysql); return 0;
    }

    Mohl byste mi prosím poradit kde dělám chybu ? Děkuju.
    Pamatujte si, kde jste byli, když jste Vy začínali. To změní Váš pohled na lidi, jenž začínají teď!
    25.3.2008 14:11 kozzi | skóre: 55 | blog: vse_o_vsem | Pacman (Bratrušov)
    Rozbalit Rozbalit vše Re: C++ && MySQL
    No tak v nazvu diskuze je slovo C++, takze bych ocekaval ze pouzijes mysql++ coz je pro c++ lepsi. Ale ty vyuzivas Ceckovskou knihovnu takze otazka je jakym prikazem se to snazis kompilovat?
    Linux je jako mušketýři "jeden za všechny, všichni za jednoho"
    25.3.2008 14:46 martin.developer | blog: void | Zlín
    Rozbalit Rozbalit vše Re: C++ && MySQL
    Kurňa já už jsem z toho jelen.

    Mohl byste mi prosím napsat nějaký stručný návod jak rozběhnout v C++ práci s MySQL ?

    Děkuju moc.
    Pamatujte si, kde jste byli, když jste Vy začínali. To změní Váš pohled na lidi, jenž začínají teď!
    25.3.2008 14:52 miro | skóre: 19 | blog: miro
    Rozbalit Rozbalit vše Re: C++ && MySQL
    #include <stdio.h&rt;
    #include <mysql/mysql.h&rt;
    #include <string.h&rt;
    
    int main()
    {
      int i = 1;
      MYSQL mysql;
      MYSQL_RES *res;
      MYSQL_ROW row;
      char *query="SELECT * FROM user";
      mysql_init(&mysql);
      mysql_real_connect(&mysql, "localhost", "root", "6g8j2", "test", 0, NULL, 0);
      mysql_real_query(&mysql,query,(unsigned int) strlen(query));            //tu chybal strednik
      res=mysql_store_result(&mysql);
      printf("Pocet sloupcu %d, pocet radku: %d \n", mysql_num_fields(res),
          mysql_num_rows(res));
      while (row=mysql_fetch_row(res))
      {
        for (i=0; i<mysql_num_fields(res); i++)
          printf(row[i]);
        putchar('\n');
      }
      mysql_free_result(res);
      mysql_close(&mysql);
      mysql_close(&mysql);
      return 0;
    }
    
    Tento kod mi ide skompilovat a zlinkovat. Ci aj funguje, to uz neviem.
    25.3.2008 15:00 martin.developer | blog: void | Zlín
    Rozbalit Rozbalit vše Re: C++ && MySQL
    Tak jsem to zkusil, ale bohužel stejné chyby ( až na ten středník ). Všechny chyby jsou z mysql_com.h, nemohl byste mi poslat Váš mysql_com.h ??
    Pamatujte si, kde jste byli, když jste Vy začínali. To změní Váš pohled na lidi, jenž začínají teď!
    25.3.2008 15:04 kozzi | skóre: 55 | blog: vse_o_vsem | Pacman (Bratrušov)
    Rozbalit Rozbalit vše Re: C++ && MySQL
    zkus pouzit ten kod co jsem psal ja nize. A prekladek to pomoci prikazu:
    g++ -o nazev_programu nazev_programu.cpp -lmysqlclient
    Jo a taky by se hodilo uvest jakou mas verzi knihovny libmysqlclient a distro pokud si ho neuvedl uz predtim.
    Linux je jako mušketýři "jeden za všechny, všichni za jednoho"
    25.3.2008 15:06 martin.developer | blog: void | Zlín
    Rozbalit Rozbalit vše Re: C++ && MySQL
    Bohužel tady ( ve škole ) kompilujeme ve Windows a doma taky programuju jen v windousu ( jsem zvyklej na VS ).
    Pamatujte si, kde jste byli, když jste Vy začínali. To změní Váš pohled na lidi, jenž začínají teď!
    25.3.2008 15:12 miro | skóre: 19 | blog: miro
    Rozbalit Rozbalit vše Re: C++ && MySQL
    mysql_com.h

    Je to verzia z debianieho balicku libmysqlclient15-dev 5.0.51a-3. Mam aj libmysql++-dev, vo verzii 3.0.0-1.
    25.3.2008 15:18 kozzi | skóre: 55 | blog: vse_o_vsem | Pacman (Bratrušov)
    Rozbalit Rozbalit vše Re: C++ && MySQL
    V tom potiz nebude, problem je v mysql.h(spis ve visual studiu) on totiz pokud nepouzivas g++ nebo cygwin(dev-c++), tak se ti nenadefinuje promena my_socket coz spuzobuje ty chybi mozna jich je tam vic a nejde jen o my_socket ale budeto vse zalozeny na stejnem problemu. Reseni bud prepsat ty hlavickovy soubory coz nedoporucuju. Nebo pouzit dev-c++ mozna zkusit aktualizovat na novjejsi verzi toho mysql ci te knihovny nevim jak to je ve windows, ale tusim ze tam je to vse v jednom celku.
    Linux je jako mušketýři "jeden za všechny, všichni za jednoho"
    25.3.2008 15:34 miro | skóre: 19 | blog: miro
    Rozbalit Rozbalit vše Re: C++ && MySQL
    Trochu ma to zaujimalo a nieco sa naslo na nete: forums.mysql.com Treba vlozit hlavickovy subor
    #include <winsock2.h>
    25.3.2008 15:52 martin.developer | blog: void | Zlín
    Rozbalit Rozbalit vše Re: C++ && MySQL
    Tak jsem tedy přidal ten winsock2 a vyšly mi tyto chyby:
    C:\Program Files\MySQL\MySQL Server 5.0\include\mysql_com.h(183) : error C2146: syntax error : missing ';' before identifier 'fd'
    C:\Program Files\MySQL\MySQL Server 5.0\include\mysql_com.h(183) : error C4430: missing type specifier - int assumed. Note: C++ does not support default-int
    C:\Program Files\MySQL\MySQL Server 5.0\include\mysql_com.h(183) : error C4430: missing type specifier - int assumed. Note: C++ does not support default-int
    C:\Program Files\MySQL\MySQL Server 5.0\include\mysql_com.h(358) : error C2065: 'SOCKET' : undeclared identifier
    C:\Program Files\MySQL\MySQL Server 5.0\include\mysql_com.h(358) : error C2146: syntax error : missing ')' before identifier 's'
    C:\Program Files\MySQL\MySQL Server 5.0\include\mysql_com.h(359) : error C2059: syntax error : ')'
    .\main.cpp(19) : warning C4018: '<' : signed/unsigned mismatch

    A používám tento kód:
    #include <iostream>
    #include <string>
    #include <mysql/mysql.h>
    #include <winsock2.h>
    using namespace std;
    int main()
    {
    int i = 1;
    MYSQL mysql;
    MYSQL_RES *res;
    MYSQL_ROW row;
    string query="SELECT * FROM user";
    mysql_init(&mysql);
    mysql_real_connect(&mysql,"localhost","root","6g8j2","test",0,NULL,0);
    mysql_real_query(&mysql,query.c_str(), query.size());
    res=mysql_store_result(&mysql);
    cout << "Pocet sloupcu:" << mysql_num_fields(res) << " pocet radku:" << mysql_num_rows(res) << endl;
    while(row=mysql_fetch_row(res)) {
    for(i=0;i<mysql_num_fields(res);i++) cout << row[i];
    cout << endl;
    }
    mysql_free_result(res);
    mysql_close(&mysql);
    return 0;
    }
    Pamatujte si, kde jste byli, když jste Vy začínali. To změní Váš pohled na lidi, jenž začínají teď!
    25.3.2008 15:56 miro | skóre: 19 | blog: miro
    Rozbalit Rozbalit vše Re: C++ && MySQL
    ten include winsocks skuste dat uplne na zaciatok
    25.3.2008 16:00 kozzi | skóre: 55 | blog: vse_o_vsem | Pacman (Bratrušov)
    Rozbalit Rozbalit vše Re: C++ && MySQL
    to
    include <winsock2>
    musis hodit uplne na zacatek
    Linux je jako mušketýři "jeden za všechny, všichni za jednoho"
    25.3.2008 16:22 martin.developer | blog: void | Zlín
    Rozbalit Rozbalit vše Re: C++ && MySQL
    Super už jsem se dostal k Linkování ale zase chyby:

    main.obj : error LNK2019: unresolved external symbol _mysql_close@4 referenced in function _main
    main.obj : error LNK2019: unresolved external symbol _mysql_free_result@4 referenced in function _main
    main.obj : error LNK2019: unresolved external symbol _mysql_fetch_row@4 referenced in function _main
    main.obj : error LNK2019: unresolved external symbol _mysql_num_fields@4 referenced in function _main
    main.obj : error LNK2019: unresolved external symbol _mysql_num_rows@4 referenced in function _main
    main.obj : error LNK2019: unresolved external symbol _mysql_store_result@4 referenced in function _main
    main.obj : error LNK2019: unresolved external symbol _mysql_real_query@12 referenced in function _main
    main.obj : error LNK2019: unresolved external symbol _mysql_real_connect@32 referenced in function _main
    main.obj : error LNK2019: unresolved external symbol _mysql_init@4 referenced in function _main
    C:\Documents and Settings\Martin\Dokumenty\Visual Studio 2008\Projects\Vyuka\Debug\Procvicovani.exe : fatal error LNK1120: 9 unresolved externals
    Pamatujte si, kde jste byli, když jste Vy začínali. To změní Váš pohled na lidi, jenž začínají teď!
    25.3.2008 16:24 kozzi | skóre: 55 | blog: vse_o_vsem | Pacman (Bratrušov)
    Rozbalit Rozbalit vše Re: C++ && MySQL
    no musis to linkovat stou knihovnou libmysqlclient nevim jak se to dela ve visual studiu, u me to je to parametr -lmysqlclient.
    Linux je jako mušketýři "jeden za všechny, všichni za jednoho"
    25.3.2008 16:26 miro | skóre: 19 | blog: miro
    Rozbalit Rozbalit vše Re: C++ && MySQL
    Mame u neho pivo? :-)
    25.3.2008 16:28 kozzi | skóre: 55 | blog: vse_o_vsem | Pacman (Bratrušov)
    Rozbalit Rozbalit vše Re: C++ && MySQL
    +1 :-D
    Linux je jako mušketýři "jeden za všechny, všichni za jednoho"
    25.3.2008 17:47 martin.developer | blog: void | Zlín
    Rozbalit Rozbalit vše Re: C++ && MySQL
    Kdybyste byly ze Zlína tak Vás klidně pozvu na pifo ;) Vím jak přidat knihovny do linkeru, ale nevím zkama nabrat tu libmysqlclient. Zkusil jsem googlit, ale našel jsem jen nějaké věci pro Linux, ale pro Widle nic.
    Pamatujte si, kde jste byli, když jste Vy začínali. To změní Váš pohled na lidi, jenž začínají teď!
    25.3.2008 17:52 miro | skóre: 19 | blog: miro
    Rozbalit Rozbalit vše Re: C++ && MySQL
    Pod windowsom bude treba dynamicku kniznicu mysqlclient.dll, popr. staticku mysqlclient.lib

    PS: do Zlina mam daleko :(
    25.3.2008 15:43 martin.developer | blog: void | Zlín
    Rozbalit Rozbalit vše Re: C++ && MySQL
    No tak zkusil jsem to zkompilovat v Dev-C++ a dostal jsem další hromadu chyb. A tu MySQL by měla být nejnovější.
    Pamatujte si, kde jste byli, když jste Vy začínali. To změní Váš pohled na lidi, jenž začínají teď!
    25.3.2008 14:53 kozzi | skóre: 55 | blog: vse_o_vsem | Pacman (Bratrušov)
    Rozbalit Rozbalit vše Re: C++ && MySQL
    No tak klidne muzes pouzivat tu Ceckovskou knihovnu ale pokud to ma byt v C++ tak by to melo vypadat takto:
    #include <iostream>
    #include <string>
    #include <mysql/mysql.h>
    using namespace std;
    int main()
    {
    	int i = 1;
    	MYSQL mysql;
    	MYSQL_RES *res;
    	MYSQL_ROW row;
    	string query="SELECT * FROM user";
    	mysql_init(&mysql);
    	mysql_real_connect(&mysql,"localhost","root","6g8j2","test",0,NULL,0);
    	mysql_real_query(&mysql,query.c_str(), query.size());
    	res=mysql_store_result(&mysql);
    	cout << "Pocet sloupcu:" << mysql_num_fields(res) << " pocet radku:" << mysql_num_rows(res) << endl;
    	while(row=mysql_fetch_row(res)) {
    		for(i=0;i<mysql_num_fields(res);i++) cout << row[i];
    		cout << endl;
    	}
    	mysql_free_result(res);
    	mysql_close(&mysql);
    	mysql_close(&mysql);
    	return 0;
    }
    
    Linux je jako mušketýři "jeden za všechny, všichni za jednoho"
    25.3.2008 15:05 martin.developer | blog: void | Zlín
    Rozbalit Rozbalit vše Re: C++ && MySQL
    Bohužel jak jsem psal víše, zase ty samé chyby.

    c:\program files\mysql\mysql server 5.0\include\mysql_com.h(183) : error C2146: syntax error : missing ';' before identifier 'fd'
    c:\program files\mysql\mysql server 5.0\include\mysql_com.h(183) : error C4430: missing type specifier - int assumed. Note: C++ does not support default-int
    c:\program files\mysql\mysql server 5.0\include\mysql_com.h(183) : error C4430: missing type specifier - int assumed. Note: C++ does not support default-int
    c:\program files\mysql\mysql server 5.0\include\mysql_com.h(358) : error C2065: 'SOCKET' : undeclared identifier
    c:\program files\mysql\mysql server 5.0\include\mysql_com.h(358) : error C2146: syntax error : missing ')' before identifier 's'
    c:\program files\mysql\mysql server 5.0\include\mysql_com.h(359) : error C2059: syntax error : ')'
    c:\documents and settings\martin\dokumenty\visual studio 2008\projects\vyuka\procvicovani\main.cpp(18) : warning C4018: '<' : signed/unsigned mismatch
    Pamatujte si, kde jste byli, když jste Vy začínali. To změní Váš pohled na lidi, jenž začínají teď!
    25.3.2008 15:09 kozzi | skóre: 55 | blog: vse_o_vsem | Pacman (Bratrušov)
    Rozbalit Rozbalit vše Re: C++ && MySQL
    Aha ted koukam ze tam mas windows, no tak to je trochu OT. Pravdepodobne to bude rozdil v hlavickovych souborech co mame v linuxu a co sou v oknech popripade je to potiz compilatoru koukam ze pouzivas visual studio ja mam gcc(g++) a tam jede vse dobre. Mozna skusit pouzit misto toho visual studia dev-c++
    Linux je jako mušketýři "jeden za všechny, všichni za jednoho"
    25.3.2008 14:28 miro | skóre: 19 | blog: miro
    Rozbalit Rozbalit vše Re: C++ && MySQL
    syntax error : missing ';' before identifier 'res'
    
    Upravit zdrojak, riadok zacinajuci mysql_real_query treba ukoncit bodkociarkou (cesky strednik ;-)
    25.3.2008 18:06 Luboš Doležel (Doli) | skóre: 98 | blog: Doliho blog | Kladensko
    Rozbalit Rozbalit vše admin
    Zdravím,

    programování pod Windows je na AbcLinuxu z pochopitelných důvodů offtopic. Diskuzi proto zamykám a později bude odstraněna. Díky za pochopení.

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.