C++ を使用して MySQL に接続する方法

C++ を使用して MySQL に接続する方法

C++でMySQLに接続する際の参考情報です。具体的な内容は以下のとおりです。

MySQLCon クラスの定義

クラス MySQLCon
{
 MYSQLmysql;
公共:
 int エラー番号;
 文字列エラーテキスト;
公共:
 //MySQLCon() を初期化します。
 //データベースを閉じます~MySQLCon();
 //データベースに接続します bool OpenConn(const char* host,const char* username,const char* pwd,const char* dbName,unsigned port=0);
 void GetErrorText();//エラー テキストを取得します void Close();//データベースを閉じます bool ExecuteSQL(const char* sql);//SQL ステートメントを使用しますが、データを受信できません bool QureySQL(const char* sql, vector<vector<string>>& resultSet);//SQL ステートメントを使用してデータを受信します (select ステートメント)
};

初期化操作

MySQLCon::MySQLCon()
{
 (mysql_library_init(0, nullptr, nullptr) の場合) 
 {
 cout << "CAPI の初期化に失敗しました" << std::endl;
 getchar();
 終了(1);
 }
 (mysql_init(&mysql)==nullptr)の場合
 {
 cout << "データベース変数の初期化に失敗しました" << std::endl;
 char を取得する
 終了(1);
 }
 if (mysql_options(&mysql, MYSQL_SET_CHARSET_NAME, "gbk"))
 {
 cout << "接続オプションの設定に失敗しました" << std::endl;
 char を取得する
 終了(1);
 }
}

MySQLサーバーへの接続

//パラメータは、ホスト、ユーザー名、パスワード、データベース名、ポート番号です。bool MySQLCon::OpenConn(const char* host, const char* username, const char* pwd, const char* dbName, unsigned port)
{
 //データベースに接続する if (mysql_real_connect(&mysql, host, username, pwd, dbName, port, nullptr, 0)==nullptr)
 {
 cout << "MySQL サーバーへの接続に失敗しました" << std::endl;
 //エラーテキストを取得します。GetErrorText();
 終了(1);
 false を返します。
 }
 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 ステートメントの使用

ブールMySQLCon::ExecuteSQL(const char* sql)
{
 //SQL ステートメントを使用しますが、データを受け取ることができません if (mysql_real_query(&mysql, sql, strlen(sql)))
 {
 エラーテキストを取得します。
 false を返します。
 }
 true を返します。
}
bool MySQLCon::QureySQL(const char* sql、ベクトル<ベクトル<文字列>>&結果セット)
{
 //SQL ステートメントを使用して、データをベクター コンテナーに受信します if (mysql_real_query(&mysql, sql, strlen(sql)))
 {
 エラーテキストを取得します。
 false を返します。
 }
 //MYSQL 結果セットを作成します MYSQL_RES* result = mysql_store_result(&mysql);
 //行と列の合計数を取得します unsigned int rows = mysql_num_rows(result);
 符号なし整数列 = mysql_num_fields(結果);
 // 結果セット MYSQL_ROW 行にデータの一部を記録するために使用されます。
 while (行 = mysql_fetch_row(結果))
 {
 // 行にデータを格納するためのベクター コンテナーを作成します。vector<string> lineDate;
 (int i = 0; i < cols; i++) の場合
 {
 if (行[i])
 {
 //行の各列のデータをlineDateに保存します。lineDate.push_back(row[i]);
 }
 それ以外
 {
 lineDate.push_back("");
 }
 }
 // データの行全体を resultSet に保存します resultSet.push_back(lineDate);
 }
 //結果セットを解放するmysql_free_result(result);
 true を返します。
}

データベースを閉じる

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

メイン関数の例

int メイン()
{
 MySQLCon c_apiconn;
 c_apiconn.OpenConn("127.0.0.1", "ルート", "136119", "ファンシー");
 文字列 sql = "use fancy;"
 ベクトル<ベクトル<文字列>> データ;
 c_apiconn.SQL を実行します (sql.c_str());
 sql = "fancy.infoから*を選択します;";
 c_apiconn.QureySQL(sql.c_str(), データ);
 (int i = 0; i < data.size(); i++) の場合
 {
 (int j = 0; j < data[i].size(); j++)の場合
 {
 cout << データ[i][j] << "\t";
 }
 cout << 終了;
 }
 0を返します。
}

出力

以上がこの記事の全内容です。皆様の勉強のお役に立てれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。

以下もご興味があるかもしれません:
  • C++ で MySQL データベースに接続する 2 つの方法の概要
  • Eclipse の C++ で MySQL データベースに接続する
  • C++ が MySQL-Connector/C++ を使用して MySQL に接続するときに発生する LNK2019 エラーの解決方法
  • MySql データベースに接続するための C/C++ メソッド
  • C++ で MySQL に接続する方法 (C-API を直接呼び出す)
  • MySQL API を使用して C++ でデータベースに接続および操作する例の詳細な説明
  • C++ を MySQL 5.6 に接続する際のエラーの概要
  • C++ を MySQL に接続する際に発生する問題の概要
  • C++はデータベースに接続するためにmysql独自のヘッダーファイルを使用します
  • C++ で MySQL データベースに接続する 2 つの方法 (ADO 接続と MySQL API 接続)

<<:  CentOS 7 で Docker のポート転送をファイアウォールと互換性のあるように設定する方法

>>:  22 Vue 最適化のヒント (プロジェクトの実践)

推薦する

MySQL 5.7.25 のインストールと設定方法のグラフィックチュートリアル

MySQL インストール ファイルには、msi 形式と zip 形式の 2 種類があります。クリック...

Web デザイン体験: 5 つの優れた Web デザイン コンセプトの完全分析 (画像)

他の種類のデザインとは異なり、Web デザインは時代の発展とともに常に変化しています。したがって、W...

MySQLデータベースの一般的な最適化操作のまとめ(経験共有)

序文データ中心のアプリケーションの場合、データベースの品質はプログラムのパフォーマンスに直接影響する...

画像ボタン送信とフォーム繰り返し送信の問題に関する議論

多くの場合、フォームを美しくするために、送信ボタンが画像に置き換えられます。ただし、細部に注意を払わ...

MySQLデータベース最適化技術の簡単な紹介

成熟したデータベース アーキテクチャは、最初から高可用性、高スケーラビリティなどの機能を備えて設計さ...

MySQLでのカスタムパラメータの使用に関する詳細な説明

MySQL 変数には、システム変数とシステム変数が含まれます。今回の学習課題はユーザー定義変数です。...

JS で Websocket ベースのマルチターミナル ブリッジング プラットフォームを実装する方法

目次1. デバッグ対象2. WebSocketの機能3. ソケット接続を確立する3.1 部屋の作成方...

JavaScript で支払いの 10 秒カウントダウンを実現

この記事では、支払いの10秒カウントダウンを実現するためのJavaScriptの具体的なコードを参考...

CPU、マシンモデル、メモリなどの情報を表示するLinuxシステム

システムメンテナンス中は、いつでも CPU 使用率を確認し、対応する情報に基づいてシステムの状態を分...

Javascript ツリー メニュー (11 項目)

1. dhtmlxツリー dHTMLxTree は機能豊富なツリー メニュー コントロールです。豊...

Vue3.0のさまざまなリスニング方法の包括的な概要

目次リスナー1.ウォッチエフェクト2.見る1.1 聴くための最初の方法1.2 聞く2つ目の方法1.3...

Reactソースコードにおけるビット演算について詳しく説明します

目次序文いくつかの一般的なビット操作ビットAND (&)ビットOR (|)ビット否定(~)マ...

CSS を使用して要素のスクロールバーを非表示にするサンプルコード

どの要素でもスクロールできるようにしながら、スクロールバーを非表示にするにはどうすればよいでしょうか...

Tomcat セキュリティ仕様 (Tomcat セキュリティ強化と仕様)

tomcat はオープンソースの Web サーバーです。Tomcat ベースの Web は実行効率...

CSS で 3D ブック効果を実装するためのサンプル コード

さっそく、レンダリングを見てみましょうソースコードは以下のとおりです <!DOCTYPE ht...