目次
1. mysql API のヘッダー ファイルをインクルードする必要があります
2. mysql に接続するための具体的な手順
2.1 mysql_real_connect
2.2 mysql_query または mysql_real_query
2.3 結果セット mysql_store_result
2.4 結果セット内のデータの各行を表示します。
3. プログラミングの例
ホームページ データベース mysql チュートリアル C++ で mysql データベースに接続してデータを読み取る方法

C++ で mysql データベースに接続してデータを読み取る方法

Jun 03, 2023 am 09:05 AM
mysql c++

    1. mysql API のヘッダー ファイルをインクルードする必要があります

    ローカルの mysql データベースに接続する必要がある場合は、mysql がデータベースはローカルにインストールされている必要があります。ここでは、データベースへの接続、クエリ ステートメントの実行、その他の操作など、一部の mysql API が使用されています。これらのインターフェイスは、次のヘッダー ファイルに含まれています:

    #include <mysql/mysql.h>
    ログイン後にコピー

    2. mysql に接続するための具体的な手順

    ここでは、大きく 4 つの主要なステップに分けることができます:

    1. mysql データベースに接続します

    1. mysql データベースに接続します

    明らかに、 mysql データ内のデータを取得するには、まずデータベースに接続し、データベースを操作できるハンドルを取得する必要があります。

    2. クエリ ステートメントを実行します。つまり、必要なデータを選択します。

    は、クエリ ステートメントを実行し、必要なデータをクエリします。クエリされたデータは結果セットと呼ばれる場所に保存されます。

    3. 結果セットから必要なデータを取得する

    関連するインターフェイス関数を使用して、結果セットから各行とローカル フィールドのデータを取得します。

    4. 結果セットから各行の各フィールドの情報を抽出

    5. 結果セットmysqlハンドルを含むリソースを解放

    以下で詳しく説明します使用する必要のあるいくつかの主要なインターフェイス機能。

    2.1 mysql_real_connect

    この関数は、ホスト上で実行されているデータベース エンジンに接続するために使用されます。接続に成功するとデータベースを操作できるハンドルが取得され、失敗した場合は NULL ポインタが取得されます。返されます。

    MYSQL *mysql_real_connect(MYSQL *mysql, 
    						const char *host, 
    						const char *user, 
    						const char *passwd, 
    						const char *db, 
    						unsigned int port, 
    						const char *unix_socket, 
    						unsigned long client_flag
    						)
    ログイン後にコピー

    この関数には多くのパラメータがあり、各パラメータの意味は次のとおりです:

    • mysql: 既存のMYSQL 構造。 mysql_real_connect() を呼び出す前に、mysql_init() を呼び出して MYSQL 構造を初期化する必要があります。

    • #host: ホスト名または IP アドレスです。 「host」が NULL または文字列「localhost」の場合、接続は localhost への接続として扱われます。

    • #user: ユーザーの MySQL ログイン ID。 「user」が NULL または空の文字列「" の場合、そのユーザーは現在のユーザーとみなされます。

    • passwd: ユーザーのパスワード。 「passwd」が NULL の場合、ユーザーのユーザー テーブル内のエントリ (パスワード フィールドが空のもの) のみが一致するかどうかチェックされます。

    • db: データベース名です。 db が NULL の場合、接続によりデフォルトのデータベースがこの値に設定されます。

    • port: 「port」が 0 でない場合、その値が TCP/IP 接続のポート番号として使用されます。 「ホスト」パラメータによって接続のタイプが決定されることに注意してください。

    • unix_socket: unix_socket が NULL でない場合、この文字列は使用するソケットまたは名前付きパイプを記述します。 「ホスト」パラメータによって接続のタイプが決定されることに注意してください。

    • client_flag: 値は通常 0

    2.2 mysql_query または mysql_real_query

    この関数はused クエリ コマンドをデータベースに送信し、データベースに実行させます。 0 を返すとクエリが成功したことを示し、それ以外の場合は失敗します。

    int mysql_query(MYSQL *mysql, const char *stmt_str)
    ログイン後にコピー

    Or:

    int
    mysql_real_query(MYSQL *mysql,
                     const char *stmt_str,
                     unsigned long length)
    ログイン後にコピー
    • mysql: を通じて取得された mysql 操作ハンドルです。

    • stmt_str: 実行する必要があるクエリ ステートメントを示します。

    • #length: クエリ ステートメントの長さです。

    上記 2 つの関数の違いは次のとおりです。

    • mysql_query() はバイナリ ステートメント、つまりパラメータ stmt_str の実行には使用できません。できません 文字に解析されるバイナリ データがあります。

    • mysql_query クエリ速度は、クエリ ステートメントの長さを計算する必要があるため、若干遅くなります。

    2.3 結果セット mysql_store_result

    を取得します。

    関数は、クエリが成功した場合は結果セットを返します。失敗した場合は、NULL を返します。

    MYSQL_RES *mysql_store_result(MYSQL *mysql)
    ログイン後にコピー

    2.4 結果セット内のデータの各行を表示します。

    次の入力パラメータこの関数は、ステップ (3) で返された結果セットです。呼び出されるたびに、結果セットの次のデータ行が返され、ポインタは 1 行後方に移動します。次のデータ行がない場合は、NULL が返されます。
    mysql_num_fields(result) を使用して結果セット内の行数を計算し、mysql_num_fields(result) を使用して列数を計算できます。 rowが、ある行の情報であれば、row[0]、row[1]となります。 。 。行の各フィールド情報。

    MYSQL_ROW mysql_fetch_row(MYSQL_RES *result)
    ログイン後にコピー

    3. プログラミングの例

    ここでの環境は Linux システムです。使用されるローカル データベース名は CrashCourse、クエリ テーブル名は products です。次のプログラミング例は、products テーブル内の価格が 30 を超えるすべてのアイテムをクエリする方法を示しています。 products テーブルの完全な内容は次のとおりです:

    C++ で mysql データベースに接続してデータを読み取る方法

    #include 
    #include <mysql/mysql.h>
    #include 
    using namespace std;
     
    MYSQL mysql;  //mysql连接
    MYSQL_RES* res; //结果集结构体   
    MYSQL_ROW row; //char** 二维数组,存放记录  
     
    int main()
    {	
    	// 步骤1: 初始化并连接数据库,获得操作数据库的句柄
    	mysql_init(&mysql);    //初始化
    	if (!(mysql_real_connect(&mysql, "localhost", "root", "root", "CrashCourse", 0, NULL, 0))) {
    		cout << "Couldn't connect to Database!\n : " << mysql_error(&mysql);
    		exit(1);
    	}
    	else {
    		printf("Database connection succeeded. Connected...\n\n");
    	}
    	// 步骤2: 执行查询语句,查询需要的数据(设置编码格式也相当于执行特殊的查询语句)
    	mysql_query(&mysql, "set names gbk"); // 设置编码格式
    	mysql_query(&mysql, "SELECT * from products where prod_price > 30");
     
    	// 步骤3:获取结果集
    	res = mysql_store_result(&mysql);
    	// 步骤4:显示结果集中每行数据
        int cols = mysql_num_fields(res); // 计算结果集中,列的个数
    	while (row = mysql_fetch_row(res)) {
        
        	for (int i = 0; i < cols; ++i) {
          		cout << row[i] << "\t";
        	}
        	cout << endl;
    	}
     	// 步骤5:释放结果集合mysql句柄
    	mysql_free_result(res);
    	mysql_close(&mysql);
     return 0;
     
    }
    ログイン後にコピー

    クエリの結果は次のとおりです:

    C++ で mysql データベースに接続してデータを読み取る方法

    以上がC++ で mysql データベースに接続してデータを読み取る方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

    このウェブサイトの声明
    この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

    ホットAIツール

    Undresser.AI Undress

    Undresser.AI Undress

    リアルなヌード写真を作成する AI 搭載アプリ

    AI Clothes Remover

    AI Clothes Remover

    写真から衣服を削除するオンライン AI ツール。

    Undress AI Tool

    Undress AI Tool

    脱衣画像を無料で

    Clothoff.io

    Clothoff.io

    AI衣類リムーバー

    AI Hentai Generator

    AI Hentai Generator

    AIヘンタイを無料で生成します。

    ホットツール

    メモ帳++7.3.1

    メモ帳++7.3.1

    使いやすく無料のコードエディター

    SublimeText3 中国語版

    SublimeText3 中国語版

    中国語版、とても使いやすい

    ゼンドスタジオ 13.0.1

    ゼンドスタジオ 13.0.1

    強力な PHP 統合開発環境

    ドリームウィーバー CS6

    ドリームウィーバー CS6

    ビジュアル Web 開発ツール

    SublimeText3 Mac版

    SublimeText3 Mac版

    神レベルのコード編集ソフト(SublimeText3)

    C++ で戦略デザイン パターンを実装するにはどうすればよいですか? C++ で戦略デザイン パターンを実装するにはどうすればよいですか? Jun 06, 2024 pm 04:16 PM

    C++ でストラテジ パターンを実装する手順は次のとおりです。ストラテジ インターフェイスを定義し、実行する必要があるメソッドを宣言します。特定の戦略クラスを作成し、それぞれインターフェイスを実装し、さまざまなアルゴリズムを提供します。コンテキスト クラスを使用して、具体的な戦略クラスへの参照を保持し、それを通じて操作を実行します。

    MySQL 8.4 で mysql_native_password がロードされていないエラーを修正する方法 MySQL 8.4 で mysql_native_password がロードされていないエラーを修正する方法 Dec 09, 2024 am 11:42 AM

    MySQL 8.4 (2024 年時点の最新の LTS リリース) で導入された主な変更の 1 つは、「MySQL Native Password」プラグインがデフォルトで有効ではなくなったことです。さらに、MySQL 9.0 ではこのプラグインが完全に削除されています。 この変更は PHP および他のアプリに影響します

    C++ でネストされた例外処理を実装するにはどうすればよいですか? C++ でネストされた例外処理を実装するにはどうすればよいですか? Jun 05, 2024 pm 09:15 PM

    ネストされた例外処理は、ネストされた try-catch ブロックを通じて C++ に実装され、例外ハンドラー内で新しい例外を発生させることができます。ネストされた try-catch ステップは次のとおりです。 1. 外側の try-catch ブロックは、内側の例外ハンドラーによってスローされた例外を含むすべての例外を処理します。 2. 内部の try-catch ブロックは特定のタイプの例外を処理し、スコープ外の例外が発生した場合、制御は外部例外ハンドラーに渡されます。

    C++ テンプレートの継承を使用するにはどうすればよいですか? C++ テンプレートの継承を使用するにはどうすればよいですか? Jun 06, 2024 am 10:33 AM

    C++ テンプレートの継承により、テンプレート派生クラスが基本クラス テンプレートのコードと機能を再利用できるようになり、コア ロジックは同じだが特定の動作が異なるクラスを作成するのに適しています。テンプレート継承の構文は次のとおりです: templateclassDerived:publicBase{}。例: templateclassBase{};templateclassDerived:publicBase{};。実際のケース: 派生クラス Derived を作成し、基本クラス Base のカウント関数を継承し、現在のカウントを出力する printCount メソッドを追加しました。

    クロススレッド C++ 例外を処理するにはどうすればよいですか? クロススレッド C++ 例外を処理するにはどうすればよいですか? Jun 06, 2024 am 10:44 AM

    マルチスレッド C++ では、例外処理は std::promise および std::future メカニズムを通じて実装されます。promise オブジェクトを使用して、例外をスローするスレッドで例外を記録します。 future オブジェクトを使用して、例外を受信するスレッドで例外を確認します。実際のケースでは、Promise と Future を使用して、さまざまなスレッドで例外をキャッチして処理する方法を示します。

    Redis Exporter サービスを使用した Redis ドロップレットの監視 Redis Exporter サービスを使用した Redis ドロップレットの監視 Jan 06, 2025 am 10:19 AM

    Redis データベースを効果的に監視することは、最適なパフォーマンスを維持し、潜在的なボトルネックを特定し、システム全体の信頼性を確保するために不可欠です。 Redis Exporter Service は、Prometheus を使用して Redis データベースを監視するように設計された堅牢なユーティリティです。 このチュートリアルでは、Redis Exporter Service の完全なセットアップと構成について説明し、監視ソリューションをシームレスに確立できるようにします。このチュートリアルに従うことで、Redis データベースのパフォーマンス メトリクスを効果的に監視するための完全に運用可能な監視セットアップを実現できます。

    定量通貨取引ソフトウェア 定量通貨取引ソフトウェア Mar 19, 2025 pm 04:06 PM

    この記事では、3つの主要な交換、Binance、OKX、およびgate.ioの定量的取引機能を調査し、定量的トレーダーが適切なプラットフォームを選択できるようにすることを目指しています。この記事では、最初に定量的取引の概念、利点、課題を紹介し、APIサポート、データソース、バックテストツール、リスク制御機能など、優れた定量的取引ソフトウェアが持つべき機能を説明します。その後、3つの交換の定量的取引機能を比較し、詳細に分析し、それぞれその利点と短所を指摘し、最終的にさまざまなレベルの経験の定量的トレーダーにプラットフォーム選択の提案を提供し、リスク評価と戦略的バックテストの重要性を強調しました。 あなたが初心者であろうと経験豊富な定量的トレーダーであろうと、この記事はあなたに貴重なリファレンスを提供します

    C++ メモリ管理はどのようにしてメモリ使用量を最適化しますか? C++ メモリ管理はどのようにしてメモリ使用量を最適化しますか? Jun 05, 2024 pm 10:41 PM

    C++ メモリ管理の最適化手法には、スマート ポインタ (RAII) の使用、頻繁な割り当ての削減、不必要なコピーの回避、低レベル API の使用 (注意が必要)、メモリ使用量の分析が含まれます。画像処理アプリケーションでのスマート ポインターやキャッシュの使用などのこれらの技術を通じて、メモリの使用量とパフォーマンスを大幅に最適化できます。

    See all articles