C 連接 MySQL 是一種常用的數(shù)據(jù)庫連接方式,如果想要連接 MySQL 數(shù)據(jù)庫,需要下載 MySQL 的 C 語言連接庫。
mysql.h
可以通過以下鏈接下載 MySQL 的 C 語言連接庫:
https://dev.mysql.com/downloads/connector/c/
在下載頁面中選擇適合自己的操作系統(tǒng)和位數(shù),然后下載對應(yīng)的 zip 包。
下載完成后,需要將下載的 zip 包解壓縮到合適的路徑下,比如 Windows 操作系統(tǒng)下可以解壓縮到 C 盤根目錄。
C:\mysql-connector-c-6.1.11-win32
解壓縮完成后,需要將解壓得到的文件路徑添加到系統(tǒng)環(huán)境變量 PATH 中,以便程序能夠找到 MySQL 的 C 語言連接庫。
SET PATH=%PATH%;C:\mysql-connector-c-6.1.11-win32\bin
添加路徑后,就可以使用 C 語言代碼來連接 MySQL 數(shù)據(jù)庫了。
//連接 MySQL 數(shù)據(jù)庫
MYSQL *conn;
conn = mysql_init(NULL);
if (conn == NULL) {
printf("Error %u: %s\n", mysql_errno(conn), mysql_error(conn));
exit(1);
}
if (mysql_real_connect(conn, "localhost", "user", "password", "database", 0, NULL, 0) == NULL) {
printf("Error %u: %s\n", mysql_errno(conn), mysql_error(conn));
exit(1);
}
//執(zhí)行 SQL 語句
if (mysql_query(conn, "SELECT * FROM table")) {
printf("Error %u: %s\n", mysql_errno(conn), mysql_error(conn));
exit(1);
}
MYSQL_RES *res;
res = mysql_store_result(conn);
if (res == NULL) {
printf("Error %u: %s\n", mysql_errno(conn), mysql_error(conn));
exit(1);
}
MYSQL_ROW row;
while ((row = mysql_fetch_row(res)) != NULL) {
printf("%s %s %s\n", row[0], row[1], row[2]);
}
mysql_free_result(res);
//關(guān)閉數(shù)據(jù)庫連接
mysql_close(conn);
以上代碼中,需要修改的部分是連接 MySQL 數(shù)據(jù)庫的參數(shù),包括主機(jī)名、用戶名、密碼和數(shù)據(jù)庫名。