$url = "mysql-c-rw.php"; $tipo = 'e';
$index = false; $pubblicita = true;
$title = "Guida MySQL: Accesso a MySQL da C";
include("../include/page_struct_initial.php");
include("../visite.php");
?>
/*include("../pubblicita/pubblicita_testa.php");*/ ?>
include("../include/article_header.php");
write_article_header("Guida MySQL: Accesso a MySQL da C",
"9 Gennaio 2008",
"Database",
"",
0,
"g");
?>
include("../pubblicita/annunci_google_testa.php"); ?>
Per effettuare le query vi sono due funzioni a disposizione,
mysql_query() e mysql_real_query().
La prima si aspetta che il testo della query sia una stringa che termini con un carattere NULL,
e non può essere usata per quelle query che contengono dati binari.
Se la query contiene dati binari (che potrebbero contenere byte NULL,
"\0", che potrebbero essere
erroneamente interpretati come la fine della stringa di query) si deve usare la
mysql_real_query().
Ci sono due modi per un client di elaborare il result set. Un modo è
quello di ottenere l’intero result set in una sola volta chiamando
mysql_store_result()
(mysql_store_result() leggerà l'intero risultato
della query, allocherà una struttura MYSQL_RES ed inserirà i risultati
in questa struttura. Restituirà NULL se la query non ha prodotto un result set o se fallisce la
lettura del result set), il secondo modo è quello di ottenere una riga per
volta usando la funzione mysql_use_result().
include("../pubblicita/pubblicita_fine.php"); ?>
In entrambi i casi si può accedere alle righe usando la funzione
mysql_fetch_row(). Se si è usata la funzione mysql_store_result()
per ottenere il result set la mysql_fetch_row() preleverà la riga da
un set già prelevato, mentre se è usata la funzione mysql_use_result()
la mysql_fetch_row() preleverà la riga direttamente dal server.
Un vantaggio nell’utilizzo della mysql_store_result() consiste nel fatto
che una volta prelevate tutte le righe si potrà accedere al result set sia in maniera
sequenziale, cioè una riga dopo l’altra, sia accedendo direttamente alla riga voluta, per
farlo si possono usare le due funzioni mysql_data_seek() e
mysql_row_seek().
Uno svantaggio sta nel notevole uso di memoria che il caricare l’intero result set in una volta
produrrebbe, mentre l’uso della mysql_use_result() richiederebbe poca
memoria per caricare una sola riga alla volta.
Si può accedere alle informazioni contenute nei campi: in modo sequenziale
usando ripetutamente la funzione mysql_fetch_field() scorrendo i campi
all'interno della riga in modo sequenziale, oppure accedendo direttamente
al campo voluto indicando il numero del campo e usando la funzione
mysql_fetch_field_direct().
La posizione del cursore del campo può essere cambiata usando la funzione
mysql_field_seek().
È possibile prendere informazioni su tutti i campi usando la funzione
mysql_fetch_fields().
Dopo aver usato il result set si dovrà liberare la memoria allocata, per farlo si utilizzerà la
funzione mysql_free_result().
Per quanto riguarda gli eventuali errori usando la funzione mysql_errno()
si può determinare il codice dell’errore che è stato generato, usando la funzione
mysql_error() si potrà determinare il messaggio di errore.
Per ciascuna altra query che non sia una SELECT (ad esempio INSERT, UPDATE,
DELETE) si possono individuare le righe cercate della tabella chiamando la funzione
mysql_affected_rows().
Per le query tipo SELECT le righe selezionate saranno poste sotto forma di result set.
Le
informazioni relative alle dimensioni dei dati in ciascuna riga saranno disponibili chiamando
la funzione mysql_fetch_lengths().
Si supponga di voler leggere dalla tabella seguente
id int
cognome char(25)
nome char (25)
eta int
Il client che accede a questa tabella e ne stampa le righe è la seguente
client-r.cpp
#include <stdio.h>
#include <mysql.h>
MYSQL *conn;
MYSQL_RES *result;
MYSQL_ROW row;
char query[250];
const char* host = "localhost"; // host
const char* database = "mydb"; // database
const char* db_user = "root"; // nome utente
const char* db_pass = "passwd"; // password
int main (int argc, char *argv[])
{
conn = mysql_init (NULL);
mysql_real_connect (conn, /* connection handler */
host, /* host */
db_user, /* user name */
db_pass, /* password */
database, /* database */
0, /* porta */
NULL, /* socket */
0); /* flags */
strcpy(query, "SELECT titolo from test.persona;");
mysql_query(conn, query);
result = mysql_use_result(conn);
while ((row = mysql_fetch_row(result)))
{
printf("Id: %s Cognome: %s Nome: %s Eta: %s \n", row[0], row[1],
row[2], row[3]);
}
mysql_close (conn);
exit (0);
}
Si supponga di voler scrivere nella tabella seguente
id int
cognome char(25)
nome char (25)
eta int
Il client che accede a questa tabella legge da input i dati e li scrive
nella tabella è la seguente
client-w.cpp
#include <stdio.h>
#include <mysql.h>
MYSQL *conn;
MYSQL_RES *result;
MYSQL_ROW row;
char query[250];
char nome[30];
char cognome[30];
char ch;
char Eta[3];
int eta;
const char* host = "localhost"; // host
const char* database = "mydb"; // database
const char* db_user = "root"; // nome utente
const char* db_pass = "passwd"; // password
int main (int argc, char *argv[])
{
conn = mysql_init (NULL);
mysql_real_connect (conn, /* connection handler */
host, /* host */
db_user, /* user name */
db_pass, /* password */
database, /* database */
0, /* porta */
NULL, /* socket */
0); /* flags */
do
{
printf("Inserire nome, cognome ed età\n");
scanf("%s %s %d",&nome, &cognome, &eta);
itoa(eta, Eta, 10);
strcpy(query, "INSERT into test.persona VALUES ('");
strcat(query, nome);
strcat(query, "', '");
strcat(query, cognome);
strcat(query, "', '");
strcat(query, Eta);
strcat(query, "');");
mysql_query(conn, query);
printf("Continuare? (s\n)");
ch = getchar();
} while (ch == 's');
mysql_close (conn);
exit (0);
}
include("mysql-guide-page.php"); ?>
include("../include/guide_page.php"); ?>
include("../include/page_struct_final.php"); ?>