Rumah >pembangunan bahagian belakang >C++ >Bagaimana untuk menggabungkan cin dan pangkalan data dalam c++
Cin dalam C++ boleh digabungkan dengan pangkalan data melalui perpustakaan antara muka pangkalan data (seperti MySQL Connector/C++ atau ODBC). Langkah-langkah khusus termasuk: memasang pustaka antara muka pangkalan data membuat penyataan pertanyaan;
Gabungan cin dan pangkalan data dalam C++
Gunakan cin dalam C++ untuk membaca input pengguna daripada baris arahan, manakala pangkalan data digunakan untuk menyimpan dan mengurus data. Untuk menggabungkan cin dengan pangkalan data, anda perlu menggunakan perpustakaan antara muka pangkalan data (seperti MySQL Connector/C++ atau ODBC).
Menggunakan MySQL Connector/C++
Sertakan fail pengepala yang diperlukan dalam kod C++ anda.
<code class="cpp">#include <iostream> #include <mysqlx/xdevapi.h></code>
Wujudkan sambungan pangkalan data.
<code class="cpp">mysqlx::Session session("host", "port", "user", "password", "database");</code>
Buat pernyataan pertanyaan.
<code class="cpp">std::string query = "SELECT * FROM table_name WHERE column_name = ?";</code>
Ikat input cin pada parameter pertanyaan.
<code class="cpp">mysqlx::PreparedStatement stmt = session.prepare(query); std::string input; std::cin >> input; stmt.bind("column_name", input);</code>
Lakukan pertanyaan.
<code class="cpp">mysqlx::Result res = stmt.execute();</code>
Dapatkan hasil pertanyaan.
<code class="cpp">for (auto row : res.fetchAll()) { std::cout << row[0].get<std::string>() << std::endl; }</code>
Menggunakan ODBC
Termasuk fail pengepala ODBC yang diperlukan.
<code class="cpp">#include <iostream> #include <sql.h> #include <sqlext.h></code>
Wujudkan sambungan pangkalan data.
<code class="cpp">SQLHENV henv; SQLHDBC hdbc; SQLAllocEnv(&henv); SQLAllocConnect(henv, &hdbc); SQLDriverConnect(hdbc, nullptr, "DSN", SQL_NTS, nullptr, 0, nullptr, SQL_DRIVER_NOPROMPT);</code>
Buat pemegang pernyataan SQL.
<code class="cpp">SQLHSTMT hstmt; SQLAllocStmt(hdbc, &hstmt);</code>
Tetapkan pernyataan SQL.
<code class="cpp">std::string sql = "SELECT * FROM table_name WHERE column_name = ?"; SQLBindParameter(hstmt, 1, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, 0, 0, nullptr, 0, nullptr);</code>
Ikat input cin pada pernyataan SQL.
<code class="cpp">std::string input; std::cin >> input; SQLSetParam(hstmt, 1, SQL_C_CHAR, input.c_str(), input.length(), nullptr);</code>
Laksanakan pernyataan SQL.
<code class="cpp">SQLExecute(hstmt);</code>
Dapatkan hasil pertanyaan.
<code class="cpp">SQLBindCol(hstmt, 1, SQL_C_CHAR, nullptr, 0, nullptr); while (SQLFetch(hstmt) == SQL_SUCCESS) { char buffer[1024]; SQLGetData(hstmt, 1, SQL_C_CHAR, buffer, sizeof(buffer), nullptr); std::cout << buffer << std::endl; }</code>
Atas ialah kandungan terperinci Bagaimana untuk menggabungkan cin dan pangkalan data dalam c++. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!