c語言連接mysql完整演示


 1.連接數據庫代碼

#include <stdio.h> #include <mysql/mysql.h>

int main() { MYSQL *conn;     //創建一個指向mysql數據類型的指針
    conn=mysql_init(NULL);   //mysql的初始化
    if (!conn)         //判斷是否初始化成功
 { printf("mysql初始化失敗!\n"); return EXIT_FAILURE; } conn=mysql_real_connect(conn,"localhost","lewis","123","test",0,NULL,0); //用戶名為lewis,密碼為123,連接的數據庫為test
    if (conn) { printf("數據庫連接成功!\n"); } else printf("數據庫連接失敗!\n"); mysql_close(conn); //關閉mysql連接
    return 0; }

2.創建數據庫 語句

CREATE DATABASE test(
name varchar(20),
num int(4),
sex char(4)
);

C語言連接mysql時,注意事項:

1.首先明確,我的系統是ubuntu,我的mysql是5.7*版本
2.使用c語言管理mysql數據庫,
首先,我們需要安裝在linux下操作mysql的多依賴庫,命令如下:
//如果你有clion集成開發環境,那么一般這個都是有的,但以防萬一,你還是下載試一下.

sudo apt-get install libmysqlclient-dev sudo apt-get install libmysqld-dev

 3.開發環境,如果你是沒有環境,直接用gcc那么,執行下面命令

gcc -g -o demo -I /usr/include/mysql/ demo.c -L /usr/lib64/mysql/ -lmysqlclient -lz //意思是:將demo.c文件編譯為可執行文件demo,同時使用/user/include/mysql目錄作為優先頭文件
演示和分析見:https://www.cnblogs.com/nanfengnan/p/14725278.html
//main.c 是你所要編譯的源文件 //mysql -o 后的mysql 是自定義生成的文件名 //補充一點gcc知識,其實你也可以去linux里面,輸入man gcc自己去看命令
1.gcc -o 文件名  //指定輸出的文件名,默認文件名為:文件名.out
2.gcc -c 文件名 //編譯或者匯編源文件,但不鏈接
3.gcc -g  頭文件目錄    //可執行程序包含調試信息,加g選項是為了,生成調試信息供gdb調試,不加g無法用gdb調試
4.gcc -I //指定使用的目錄作為第一個尋找使用的頭文件目錄
reference:https://www.cnblogs.com/alan666/p/8311984.html

 4.使用Clion開發環境問題

前面步驟都一樣,操作步驟:1->2->4

使用clion和gcc最大的差別就是:clion得修改一下CMakeLists.txt文件

cmake_minimum_required(VERSION 3.17) project(job C) set(CMAKE_C_STANDARD 99) 
//上邊是CMakeLists.txt原本的內容,不要修改
//下邊是要添加和修改的內容 add_executable(job main.c) target_link_libraries(CProjectName mysqlclient

//重要注釋:必須看啊
1.target_link_libraries中的CProjectName替換成實際你的C語言項目名稱)
2.target_link_libraries中引入的鏈接庫為mysqlclient,而不是libmysqlclient,使用libmysqlclient會報錯 划重點

報錯如下:所以一定要注意這里

====================[ Build | job | Debug ]=====================================
/opt/clion/clion-2020.3.2/bin/cmake/linux/bin/cmake --build /home/lewis/program/c/job/cmake-build-debug --target job -- -j 6 Scanning dependencies of target job [ 50%] Building C object CMakeFiles/job.dir/main.c.o [100%] Linking C executable job /usr/bin/ld: 找不到 -llibmysqlclient collect2: error: ld returned 1 exit status CMakeFiles/job.dir/build.make:103: recipe for target 'job' failed make[3]: *** [job] Error 1 CMakeFiles/Makefile2:95: recipe for target 'CMakeFiles/job.dir/all' failed make[2]: *** [CMakeFiles/job.dir/all] Error 2 CMakeFiles/Makefile2:102: recipe for target 'CMakeFiles/job.dir/rule' failed make[1]: *** [CMakeFiles/job.dir/rule] Error 2 Makefile:138: recipe for target 'job' failed make: *** [job] Error 2

3.查看mysql.h文件目錄

查看mysql文件,
1./usr/include/是否存在mysql.h ,若存在,在c語言中使用時用 #include<mysql.h> 2.若不存在,請看下一級目錄/usr/include/mysql/,若存在mysql.h,c語言中請使用 #include<mysql/mysql.h>
很好測試,直接去目錄里面找,或者在Clion中看是否有代碼提示

 CLion下連接數據庫結果如下:

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM