c++++ 函数库可用于数据库管理,通过<sqlite3.h> 头文件提供了一系列函数,支持连接、创建表、插入数据、查询、事务处理等操作,该库适用于管理与数据库交互的常见任务。

C++ 函数库用于数据库管理
C++ 标准库提供了广泛的函数来处理与数据库交互相关的常见任务。这些函数库主要是来自 <sqlite3.h> 头文件。
连接到数据库
立即学习“C++免费学习笔记(深入)”;
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++ 函数库如何进行数据库管理?的详细内容,更多请关注php中文网其它相关文章!
c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号