#include <stdio.h>
#include <stdlib.h>
#include <sqlite3.h>
static int callback(void *NotUsed, int argc, char **argv, char **azColName) {
for (int i = 0; i < argc; i++) {
printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL");
}
printf("\n");
return 0;
}
int main() {
sqlite3 *db;
char *zErrMsg = 0;
int rc;
rc = sqlite3_open("example.db", &db);
if (rc) {
fprintf(stderr, "无法打开数据库: %s\n", sqlite3_errmsg(db));
sqlite3_close(db);
exit(0);
} else {
fprintf(stdout, "数据库打开成功\n");
}
// 创建一个表
char *sql = "CREATE TABLE IF NOT EXISTS students(id integer, name text, score integer);";
rc = sqlite3_exec(db, sql, callback, 0, &zErrMsg);
if (rc != SQLITE_OK) {
fprintf(stderr, "SQL错误: %s\n", zErrMsg);
sqlite3_free(zErrMsg);
} else {
fprintf(stdout, "表创建成功\n");
}
// 插入数据
sql = "INSERT INTO students(id, name, score) VALUES(1, '小明', 95);";
rc = sqlite3_exec(db, sql, callback, 0, &zErrMsg);
if (rc != SQLITE_OK) {
fprintf(stderr, "SQL错误: %s\n", zErrMsg);
sqlite3_free(zErrMsg);
} else {
fprintf(stdout, "数据插入成功\n");
}
// 查询数据
sql = "SELECT * FROM students;";
rc = sqlite3_exec(db, sql, callback, 0, &zErrMsg);
if (rc != SQLITE_OK) {
fprintf(stderr, "SQL错误: %s\n", zErrMsg);
sqlite3_free(zErrMsg);
} else {
fprintf(stdout, "查询成功\n");
}
sqlite3_close(db);
return 0;
}
这段代码展示了如何在C/C++中使用SQLite3库进行基本的数据库操作,包括打开数据库、创建表、插入数据和查询数据。代码简洁,注释丰富,对于SQLite3数据库操作的初学者很有借鉴和借鉴的价值。