C++ 函数库如何进行数据库管理?
短信预约 -IT技能 免费直播动态提醒
c++++ 函数库可用于数据库管理,通过
C++ 函数库用于数据库管理
C++ 标准库提供了广泛的函数来处理与数据库交互相关的常见任务。这些函数库主要是来自 <sqlite3.h></sqlite3.h>
头文件。
连接到数据库
sqlite3 *db;
int rc = sqlite3_open("database.db", &db);
创建表
char *zErrMsg = 0;
int rc = sqlite3_exec(db, "CREATE TABLE IF NOT EXISTS mytable (id INTEGER PRIMARY KEY, name TEXT)", NULL, 0, &zErrMsg);
插入数据
sqlite3_stmt *stmt;
sqlite3_prepare_v2(db, "INSERT INTO mytable (name) VALUES (?)", -1, &stmt, NULL);
sqlite3_bind_text(stmt, 1, "John Doe", -1, SQLITE_STATIC);
sqlite3_step(stmt);
sqlite3_finalize(stmt);
查询数据
sqlite3_stmt *stmt;
sqlite3_prepare_v2(db, "SELECT name FROM mytable WHERE id=?", -1, &stmt, NULL);
sqlite3_bind_int(stmt, 1, 1);
while (sqlite3_step(stmt) == SQLITE_ROW) {
printf("%s\n", sqlite3_column_text(stmt, 0));
}
sqlite3_finalize(stmt);
事务处理
sqlite3_exec(db, "BEGIN TRANSACTION");
// 执行多条查询
sqlite3_exec(db, "COMMIT");
实战案例:管理学生信息数据库
#include <iostream>
#include <sqlite3.h>
using namespace std;
int main() {
sqlite3 *db;
int rc = sqlite3_open("students.db", &db);
if (rc) {
cerr << "Error opening database: " << sqlite3_errmsg(db) << endl;
return -1;
}
// 创建表
char *zErrMsg = 0;
rc = sqlite3_exec(db, "CREATE TABLE IF NOT EXISTS students (id INTEGER PRIMARY KEY, name TEXT, age INTEGER)", NULL, 0, &zErrMsg);
if (rc) {
cerr << "Error creating table: " << zErrMsg << endl;
sqlite3_free(zErrMsg);
sqlite3_close(db);
return -1;
}
// 插入数据
sqlite3_stmt *stmt;
rc = sqlite3_prepare_v2(db, "INSERT INTO students (name, age) VALUES (?, ?)", -1, &stmt, NULL);
if (rc) {
cerr << "Error preparing insert statement: " << sqlite3_errmsg(db) << endl;
sqlite3_close(db);
return -1;
}
// 插入多条数据
for (int i = 0; i < 5; i++) {
sqlite3_bind_text(stmt, 1, "Student " + to_string(i), -1, SQLITE_STATIC);
sqlite3_bind_int(stmt, 2, 20 + i);
sqlite3_step(stmt);
sqlite3_reset(stmt);
}
sqlite3_finalize(stmt);
// 查询数据
stmt = nullptr;
rc = sqlite3_prepare_v2(db, "SELECT * FROM students", -1, &stmt, NULL);
if (rc) {
cerr << "Error preparing select statement: " << sqlite3_errmsg(db) << endl;
sqlite3_close(db);
return -1;
}
while (sqlite3_step(stmt) == SQLITE_ROW) {
int id = sqlite3_column_int(stmt, 0);
const char *name = sqlite3_column_text(stmt, 1);
int age = sqlite3_column_int(stmt, 2);
cout << "Record " << id << ": Name = " << name << ", Age = " << age << endl;
}
sqlite3_finalize(stmt);
sqlite3_close(db);
return 0;
}
通过运行此程序,可以在名为 "students.db" 的数据库中创建一张名为 "students" 的表,其中包含三个列:id、name 和 age。它还会插入五条测试数据并查询数据库以检索学生信息。
以上就是C++ 函数库如何进行数据库管理?的详细内容,更多请关注编程网其它相关文章!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341