欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL系列教程之使用C語言來連接數(shù)據(jù)庫

 更新時(shí)間:2022年09月02日 12:38:56   作者:哎呀是小張啊  
c語言操作Mysql數(shù)據(jù)庫,主要就是為了實(shí)現(xiàn)對(duì)數(shù)據(jù)庫的增、刪、改、查等操作,下面這篇文章主要給大家介紹了關(guān)于MySQL系列教程之使用C語言來連接數(shù)據(jù)庫的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下

寫在前面

知道了 Java中使用 JDBC編程 來連接數(shù)據(jù)庫了,但是使用 C語言 來連接數(shù)據(jù)庫卻總是連接不上去~

立即安排一波使用 C語言連接 MySQL數(shù)據(jù)庫的教程~

一、準(zhǔn)備工作

1.1 把 libmysql.dll 和 libmysql.lib 文件復(fù)制到工程目錄下

首先,我們要找到剛剛開始下載的 MySQL數(shù)據(jù)庫 的安裝目錄,打開目錄,并且將 libmysql.dll文件 和 libmysql.lib文件 復(fù)制到工程目錄下~

我安裝MySQL的路徑:C:\Program Files\MySQL\MySQL Server 5.7\lib

1.2 添加 libmysql.lib 

1.3 添加 include目錄

我的這個(gè)路徑是:C:\Program Files\MySQL\MySQL Server 5.7\include 

來到 VS2019 頁面,和上述操作一樣~

右鍵MySQL工程,選擇屬性 右鍵,選擇 C/C++,選擇常規(guī),選擇 附加包含目錄,同時(shí)進(jìn)行編輯,將剛剛復(fù)制的 include路徑 給粘貼上去~

1.4 包含頭文件

接下來 在VS2019里面,先后敲出代碼:

#include <WinSock.h> 和 #include <mysql.h> ,需要注意的是,兩行代碼的順序不可以改變~ 

1.5 其他準(zhǔn)備工作

1.5.1 代碼準(zhǔn)備

#include <iostream>
using namespace std;
#include <WinSock.h>
#include <mysql.h>
 
void test();
 
int main()
{
	cout << "main" << endl;
 
	test();
	getchar();
	return 0;
}
 
void test() 
{
	printf("test\n");
 
	MYSQL m;        //mysql連接
	MYSQL_RES* res; //查詢結(jié)果集
	MYSQL_ROW row;  //二維數(shù)組,存放數(shù)據(jù)
 
	//初始化數(shù)據(jù)庫
	mysql_init(&m);
 
	//設(shè)置編碼方式
	mysql_options(&m, MYSQL_SET_CHARSET_NAME, "gbk");
 
	//連接數(shù)據(jù)庫
	if (mysql_real_connect(&m, "localhost", "root", "111111", "c",      3306, NULL, 0))
	{                           //主機(jī)       用戶名   密碼      數(shù)據(jù)庫名  端口
		printf("數(shù)據(jù)庫連接成功\n");
	}
	else {
		printf("數(shù)據(jù)庫連接失敗:%s \n", mysql_error(&m));
		//輸出錯(cuò)誤信息
	}
}

1.5.2 創(chuàng)建數(shù)據(jù)庫連接

第一步,Win+R,輸入 cmd~

 第二步,輸入 musql -uroot -p,回車后,輸入一開始安裝MySQL數(shù)據(jù)庫是設(shè)置的密碼,之后回車進(jìn)入數(shù)據(jù)庫~

第三步,開始創(chuàng)建一個(gè)新的數(shù)據(jù)庫,并且開始建表之類的操作~

1.6 選擇相應(yīng)方案配置 Release,解決方案平臺(tái) x64

最終,來運(yùn)行一下代碼,發(fā)現(xiàn)已經(jīng)成功了~

 二、代碼測試案例

在經(jīng)過上述的一系列操作之后,已經(jīng)可以連接上 MySQL數(shù)據(jù)庫中了~

接下來我們就可以來做一些測試案例~

2.1 向數(shù)據(jù)庫插入數(shù)據(jù)

此時(shí),再插入數(shù)據(jù)之前,我們可以來看一看 上面新建的 student表 是沒有任何數(shù)據(jù)的~

但是,在加入 插入數(shù)據(jù)的代碼之后,運(yùn)行一下,我們就會(huì)發(fā)現(xiàn) 多出來一條數(shù)據(jù)~

 當(dāng)然,改成插入多條數(shù)據(jù)也是可以的啦~

2.2 向數(shù)據(jù)庫刪除數(shù)據(jù)

2.3 修改數(shù)據(jù)

沒修改之前:

修改之后:

2.4 查詢數(shù)據(jù),打印出來

三、使用C語言連接MySQL數(shù)據(jù)庫 的測試案例代碼

 
/*
 	//向數(shù)據(jù)庫插入數(shù)據(jù)
	const char* sql = "insert into student values(2,'李四','女'),(3,'王五','男'),"
		"(4, '趙六', '女')";
	if (mysql_query(&m, sql))
	{
		printf("插入數(shù)據(jù)失敗:%s \n", mysql_error(&m));
	}
	else
	{
		printf("插入數(shù)據(jù)成功\n");
	}
 
 
	//向數(shù)據(jù)庫刪除數(shù)據(jù)
	const char* sql_2 = "delete from student where name = '趙六'";
	if (mysql_query(&m, sql_2))
	{
		printf("刪除數(shù)據(jù)失?。?s \n", mysql_error(&m));
	}
	else
	{
		printf("刪除數(shù)據(jù)成功\n");
	}
 
 
	//向數(shù)據(jù)庫修改數(shù)據(jù)
	const char* sql_3 = "update student set id = 5 where name = '李四'";
	if (mysql_query(&m, sql_3))
	{
		printf("修改數(shù)據(jù)失敗:%s \n", mysql_error(&m));
	}
	else
	{
		printf("修改數(shù)據(jù)成功\n");
	}
*/
	//需要注意的是,在下面的設(shè)置中,所查詢到的數(shù)據(jù) 與打印出來的數(shù)據(jù)要相互匹配,
	//不然就會(huì)出現(xiàn)亂碼的
	//查詢數(shù)據(jù)
	const char* sql_4 = "select id,sex,name from student where name = '張三'";
	if (mysql_query(&m, sql_4)) 
	{
		printf("未查到記錄:%s \n", mysql_error(&m));
	}
	else
	{
		printf("查詢成功 \n");
	}
	//獲取查詢結(jié)果集
	res = mysql_store_result(&m);
	if (res)
	{
		printf("獲取到數(shù)據(jù)\n");
	}
	else
	{
		printf("未獲取到數(shù)據(jù):%s \n", mysql_error(&m));
	}
	//打印獲取到的數(shù)據(jù)
	printf("id\tname\tsex\n");
	while (row = mysql_fetch_row(res)) 
	{
		printf("%s\t%s\t%s\n", row[0], row[1], row[2]);
	}
	//釋放資源
	mysql_free_result(res);//釋放結(jié)果集
	mysql_close(&m);//關(guān)閉數(shù)據(jù)庫
}

使用 C語言 連接 MySQL數(shù)據(jù)庫,正好可以和 Java 連接 MySQL數(shù)據(jù)庫 相互映襯~

總結(jié)

到此這篇關(guān)于MySQL系列教程之使用C語言來連接數(shù)據(jù)庫的文章就介紹到這了,更多相關(guān)C語言連接MySQL數(shù)據(jù)庫內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 帶你分分鐘玩轉(zhuǎn)C語言指針

    帶你分分鐘玩轉(zhuǎn)C語言指針

    c語言指針其實(shí)是一個(gè)整形變量,與其它數(shù)據(jù)不同的是,它的作用是用來存儲(chǔ)其它變量的地址,下面這篇文章主要給大家介紹了關(guān)于C語言指針的相關(guān)資料,需要的朋友可以參考下
    2022-06-06
  • 詳解如何使用C++寫一個(gè)線程安全的單例模式

    詳解如何使用C++寫一個(gè)線程安全的單例模式

    這篇文章主要為大家詳細(xì)介紹了如何使用C++寫一個(gè)線程安全的單例模式,文中的示例代碼講解詳細(xì),具有一定的學(xué)習(xí)價(jià)值,感興趣的小伙伴可以了解一下
    2022-10-10
  • C++編寫的WebSocket服務(wù)端客戶端實(shí)現(xiàn)示例代碼

    C++編寫的WebSocket服務(wù)端客戶端實(shí)現(xiàn)示例代碼

    本文主要介紹了C++編寫的WebSocket服務(wù)端客戶端實(shí)現(xiàn)示例代碼,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • C++實(shí)現(xiàn)ini文件讀寫的示例代碼

    C++實(shí)現(xiàn)ini文件讀寫的示例代碼

    這篇文章主要介紹了C++如何實(shí)現(xiàn)讀寫ini配置文件,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2022-05-05
  • C語言實(shí)現(xiàn)簡單的掃雷小游戲

    C語言實(shí)現(xiàn)簡單的掃雷小游戲

    這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)簡單的掃雷小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-10-10
  • C++單例模式應(yīng)用實(shí)例

    C++單例模式應(yīng)用實(shí)例

    這篇文章主要介紹了C++單例模式應(yīng)用實(shí)例,詳細(xì)講述了單例模式的原理與結(jié)構(gòu),及相關(guān)的打印機(jī)應(yīng)用實(shí)例,需要的朋友可以參考下
    2014-10-10
  • 如何應(yīng)用C++的函數(shù)對(duì)象

    如何應(yīng)用C++的函數(shù)對(duì)象

    C++函數(shù)對(duì)象是C語言程序的主要組成部分,一個(gè)函數(shù)可以調(diào)用其他函數(shù)。在設(shè)計(jì)良好的程序中,每個(gè)函數(shù)都有特定的目的。本文將介紹C++函數(shù)對(duì)象的應(yīng)用,有需要的可以參考學(xué)習(xí)。
    2016-08-08
  • C++實(shí)現(xiàn)LeetCode(14.最長共同前綴)

    C++實(shí)現(xiàn)LeetCode(14.最長共同前綴)

    這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(14.最長共同前綴),本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • C++聯(lián)合體union用法實(shí)例詳解

    C++聯(lián)合體union用法實(shí)例詳解

    這篇文章主要介紹了C++聯(lián)合體union用法,較為詳細(xì)的分析了C++中聯(lián)合體的概念、實(shí)用技巧及相關(guān)注意事項(xiàng),需要的朋友可以參考下
    2015-05-05
  • C語言深入探索之單鏈表與typedef的用法

    C語言深入探索之單鏈表與typedef的用法

    typedef為C語言的關(guān)鍵字,作用是為一種數(shù)據(jù)類型定義一個(gè)新名字,單鏈表是后面要學(xué)的雙鏈表以及循環(huán)鏈表的基礎(chǔ),要想繼續(xù)深入了解數(shù)據(jù)結(jié)構(gòu)以及C語言,我們就要奠定好這塊基石!接下來就和我一起學(xué)習(xí)吧
    2022-05-05

最新評(píng)論