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

C++連接使用MySQL的方法

 更新時間:2020年07月29日 09:53:12   作者:AntiFancy  
這篇文章主要為大家詳細(xì)介紹了C++連接使用MySQL的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下

C++連接使用MySQL,供大家參考,具體內(nèi)容如下

定義MySQLCon類

class MySQLCon
{
 MYSQL mysql;
public:
 int errornum;
 string errortext;
public:
 //初始化
 MySQLCon();
 //關(guān)閉數(shù)據(jù)庫
 ~MySQLCon();
 //鏈接數(shù)據(jù)庫
 bool OpenConn(const char* host,const char* username,const char* pwd,const char* dbName,unsigned port=0);
 void GetErrorText();//獲取錯誤文本
 void Close();//關(guān)閉數(shù)據(jù)庫
 bool ExecuteSQL(const char* sql);//使用SQL語句,無法接收數(shù)據(jù)
 bool QureySQL(const char* sql, vector<vector<string>>& resultSet);//使用SQL語句并接收數(shù)據(jù)(select語句)
};

初始化操作

MySQLCon::MySQLCon()
{
 if (mysql_library_init(0, nullptr, nullptr)) 
 {
 cout << "CAPI初始化失敗" << std::endl;
 getchar();
 exit(1);
 }
 if (mysql_init(&mysql)==nullptr)
 {
 cout << "初始化數(shù)據(jù)庫變量失敗" << std::endl;
 getchar();
 exit(1);
 }
 if (mysql_options(&mysql, MYSQL_SET_CHARSET_NAME, "gbk"))
 {
 cout << "設(shè)置連接選項失敗" << std::endl;
 getchar();
 exit(1);
 }
}

連接到MySQL服務(wù)器

//參數(shù)分別為主機,用戶名,密碼,數(shù)據(jù)庫名,端口號
bool MySQLCon::OpenConn(const char* host, const char* username, const char* pwd, const char* dbName, unsigned port)
{
 //連接數(shù)據(jù)庫
 if (mysql_real_connect(&mysql, host, username, pwd, dbName, port, nullptr, 0)==nullptr)
 {
 cout << "連接到MySQL服務(wù)器失敗" << std::endl;
 //獲取錯誤文本
 GetErrorText();
 exit(1);
 return false;
 }
 return true;
 
}

獲取MySQL錯誤信息

void MySQLCon::GetErrorText()
{
 //獲取錯誤代碼
 errornum = mysql_errno(&mysql);
 //獲取錯誤文本
 errortext = mysql_error(&mysql);
 //打印錯誤代碼
 cout << "error num: " << errornum << std::endl;
 //打印錯誤文本
 cout << "error text: " << errortext << std::endl;
 getchar();
}

C++中使用SQL語句

bool MySQLCon::ExecuteSQL(const char* sql)
{
 //使用SQL語句但無法接收數(shù)據(jù)
 if (mysql_real_query(&mysql, sql, strlen(sql)))
 {
 GetErrorText();
 return false;
 }
 return true;
}
bool MySQLCon::QureySQL(const char* sql, vector<vector<string>>& resultSet)
{
 //使用SQL語句并接收數(shù)據(jù)至vector容器
 if (mysql_real_query(&mysql, sql, strlen(sql)))
 {
 GetErrorText();
 return false;
 }
 //創(chuàng)建一個MYSQL結(jié)果集
 MYSQL_RES* result = mysql_store_result(&mysql);
 //獲取行和列的總數(shù)
 unsigned int rows = mysql_num_rows(result);
 unsigned int cols = mysql_num_fields(result);
 //用于記錄結(jié)果集中的一條數(shù)據(jù)
 MYSQL_ROW row;
 while (row = mysql_fetch_row(result))
 {
 //創(chuàng)建一個vector容器用于儲存row中的數(shù)據(jù)
 vector<string> lineDate;
 for (int i = 0; i < cols; i++)
 {
 if (row[i])
 {
 //將row中每一列的數(shù)據(jù)存入lineDate中
 lineDate.push_back(row[i]);
 }
 else
 {
 lineDate.push_back("");
 }
 }
 //在resultSet中存入整行數(shù)據(jù)
 resultSet.push_back(lineDate);
 }
 //釋放結(jié)果集
 mysql_free_result(result);
 return true;
}

關(guān)閉數(shù)據(jù)庫

void MySQLCon::Close()
{
 mysql_close(&mysql);
}
MySQLCon::~MySQLCon()
{
 Close();
 mysql_library_end();
}

示例主函數(shù)

int main()
{
 MySQLCon c_apiconn;
 c_apiconn.OpenConn("127.0.0.1", "root", "136119", "fancy");
 string sql = "use fancy;";
 vector<vector<string>> data;
 c_apiconn.ExecuteSQL(sql.c_str());
 sql = "select * from fancy.info;";
 c_apiconn.QureySQL(sql.c_str(), data);
 for (int i = 0; i < data.size(); i++)
 {
 for (int j = 0; j < data[i].size(); j++)
 {
 cout << data[i][j] << "\t";
 }
 cout << endl;
 }
 return 0;
}

輸出內(nèi)容

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • MySQL中的數(shù)據(jù)類型binary和varbinary詳解

    MySQL中的數(shù)據(jù)類型binary和varbinary詳解

    binary和varbinary與char和varchar類型有點類似,不同的是binary和varbinary存儲的是二進制的字符串,而非字符型字符串。下面這篇文章主要給大家介紹了關(guān)于MySQL中數(shù)據(jù)類型binary和varbinary的相關(guān)資料,介紹的非常詳細(xì),需要的朋友可以參考學(xué)習(xí)。
    2017-07-07
  • mysql全文搜索 sql命令的寫法

    mysql全文搜索 sql命令的寫法

    首先,大家先去下載一份dvbbs.php beta1的代碼,解壓后先拋開php代碼,找出你的mysql手冊,如果沒有手冊那么就直接看下面的實例操作吧!
    2011-01-01
  • MySql索引原理與操作

    MySql索引原理與操作

    索引是有雙面性的,合理的建立索引可以提高數(shù)據(jù)庫的效率。但是如果沒有合理的構(gòu)建索引和使用索引,可能會導(dǎo)致索引失效或者影響數(shù)據(jù)庫性能,這篇文章主要介紹了MySql索引原理與操作
    2022-09-09
  • MySQL數(shù)據(jù)庫之聯(lián)合查詢?union

    MySQL數(shù)據(jù)庫之聯(lián)合查詢?union

    這篇文章主要介紹了MySQL數(shù)據(jù)庫之聯(lián)合查詢?union,聯(lián)合查詢就是將多個查詢結(jié)果的結(jié)果集合并到一起,字段數(shù)不變,多個查詢結(jié)果的記錄數(shù)合并,下文詳細(xì)介紹需要的小伙伴可以參考一下
    2022-06-06
  • Windows中MySQL數(shù)據(jù)庫下載以及安裝教程(最最新版)

    Windows中MySQL數(shù)據(jù)庫下載以及安裝教程(最最新版)

    這篇文章主要給大家介紹了關(guān)于Windows中MySQL數(shù)據(jù)庫下載以及安裝的相關(guān)資料,很多朋友剛開始接觸mysql數(shù)據(jù)庫服務(wù)器,對安裝使用教程不太明白,這里給大家總結(jié)下,需要的朋友可以參考下
    2023-09-09
  • mysql代碼執(zhí)行結(jié)構(gòu)實例分析【順序、分支、循環(huán)結(jié)構(gòu)】

    mysql代碼執(zhí)行結(jié)構(gòu)實例分析【順序、分支、循環(huán)結(jié)構(gòu)】

    這篇文章主要介紹了mysql代碼執(zhí)行結(jié)構(gòu),結(jié)合實例形式分析了mysql順序結(jié)構(gòu)、分支結(jié)構(gòu)與循環(huán)結(jié)構(gòu)相關(guān)原理、用法及操作注意事項,需要的朋友可以參考下
    2020-04-04
  • 安裝MySQL后,需要調(diào)整的10個性能配置項

    安裝MySQL后,需要調(diào)整的10個性能配置項

    這篇文章主要介紹了安裝MySQL后,需要調(diào)整的10個性能配置項,幫助大家更好的理解和使用MySQL數(shù)據(jù)庫,感興趣的朋友可以了解下
    2020-12-12
  • MySQL刪除數(shù)據(jù)庫的方法舉例

    MySQL刪除數(shù)據(jù)庫的方法舉例

    很久沒有使用命令行操作mysql,百度搜羅后重新整理,加強記憶便于查詢,下面這篇文章主要給大家介紹了關(guān)于MySQL刪除數(shù)據(jù)庫的相關(guān)資料,文中給出了詳細(xì)的實例代碼,需要的朋友可以參考下
    2023-04-04
  • 解決mysql模糊查詢索引失效問題的幾種方法

    解決mysql模糊查詢索引失效問題的幾種方法

    我們在使用like %通配符時常常會引起索引失效的問題。本文主要介紹了常見的幾種方法,具有一定的參考價值,感興趣的可以了解一下
    2021-06-06
  • mysql 5.7.17 安裝配置方法圖文教程(windows)

    mysql 5.7.17 安裝配置方法圖文教程(windows)

    這篇文章主要為大家分享了mysql 5.7.17 安裝配置方法圖文教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-01-01

最新評論