c++ 调用 sqlite
#include <iostream> #include "sqlite3.h" using namespace std; void dbTest() { #pragma region 打开或创建数据库 /*打开或创建的数据库实例句柄*/ sqlite3 *db = NULL; /*数据库文件的路径及文件名*/ const char * path = "./sqlcipher.db"; /*根据文件路径打开数据库连接。如果数据库不存在,则创建。数据库文件的路径必须以C字符串传入*/ int result = sqlite3_open_v2(path, &db, SQLITE_OPEN_READWRITE | SQLITE_OPEN_CREATE | SQLITE_OPEN_NOMUTEX | SQLITE_OPEN_SHAREDCACHE, NULL); if (result == SQLITE_OK) cout << "打开数据库连接成功" << endl; else cout << "打开数据库连接失败" << endl; #pragma endregion #pragma region 创建数据库表 const char *sqlCreateTable = "CREATE TABLE [t1](id integer PRIMARY KEY AUTOINCREMENT UNIQUE, name varchar);"; sqlite3_stmt *stmtCreateTable = NULL; /*检查语句合法性,-1代表系统会自动计算SQL语句的长度*/ result = sqlite3_prepare_v2(db, sqlCreateTable, -1, &stmtCreateTable, NULL); if (result == SQLITE_OK) { /*执行该SQL语句*/ sqlite3_step(stmtCreateTable); cout << "CREATE TABLE 语句执行成功" << endl; } else { cout << "CREATE TABLE 语句语法不正确:" << sqlite3_errmsg(db) << endl; } sqlite3_finalize(stmtCreateTable); #pragma endregion #pragma region 向数据库中插入数据 const char *sqlInsert = "INSERT INTO t1(name) VALUES('张三'); "; sqlite3_stmt *stmtInsert = NULL; /*检查语句合法性,-1代表系统会自动计算SQL语句的长度*/ result = sqlite3_prepare_v2(db, sqlInsert, -1, &stmtInsert, NULL); if (result == SQLITE_OK) { /*执行该SQL语句*/ sqlite3_step(stmtInsert); cout << "INSERT 语句执行成功" << endl; } else { cout << "INSERT 语句语法不正确:" << sqlite3_errmsg(db) << endl; } sqlite3_finalize(stmtInsert); #pragma endregion #pragma region 从数据库中查询数据 const char *sqlQuery = "SELECT * FROM t1;"; sqlite3_stmt *stmtQuery = NULL; /*检查语句合法性,-1代表系统会自动计算SQL语句的长度*/ result = sqlite3_prepare_v2(db, sqlQuery, -1, &stmtQuery, NULL); if (result == SQLITE_OK) { /*执行该SQL语句*/ while (sqlite3_step(stmtQuery) == SQLITE_ROW) { // 取出第0列字段的值 int id = sqlite3_column_int(stmtQuery, 0); // 取出第1列字段的值 const unsigned char *name = sqlite3_column_text(stmtQuery, 1); //输出相关查询的数据 cout << "id:" << id << ", name: " << name << endl; } } else { cout << "SELECT 语句语法不正确:" << sqlite3_errmsg(db) << endl; } sqlite3_finalize(stmtQuery); #pragma endregion sqlite3_close(db); } int main(int argc, char *argv[]) { dbTest(); char sz[] = "End !"; cout << sz << endl; return 0; }
桂棹兮兰桨,击空明兮溯流光。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!
2018-11-19 AutoCompleteExtender 使用示例