Windows下使用C++操作SQLite

由于项目中要使用到SQLite数据库,所以特地学习记录下来

首先

先去官网下载源代码

https://www.sqlite.org/download.html

我下的是这个:

然后将解压出来的四个文件新建VS项目编译成lib文件

然后将lib文件和放入到要操作SQLite 的vs工程下

加入如下代码:

cpp 复制代码
#include "sqlite3.h"
#pragma comment( lib,"sqlite3.lib" )

然后就可以开始增删改查了

SQLite C/C++ Tutorial

C/C++ Interface APIs

介绍三个主要的 API,知道这三个API就可以简单的使用sqlite3了。tutotial写得非常清楚,我直接复制过来了
1.sqlite3_open(const char *filename, sqlite3 **ppDb)

This routine opens a connection to an SQLite database file and returns a database connection object to be used by other SQLite routines.

If the filename argument is NULL or ':memory:', sqlite3_open() will create an in-memory database in RAM that lasts only for the duration of the session.

If filename is not NULL, sqlite3_open() attempts to open the database file by using its value. If no file by that name exists, sqlite3_open() will open a new database file by that name.

2.sqlite3_exec(sqlite3*, const char *sql, sqlite_callback, void *data, char **errmsg)

This routine provides a quick, easy way to execute SQL commands provided by sql argument which can consist of more than one SQL command.

Here, first argument sqlite3 is open database object, sqlite_callback is a call back for which data is the 1st argument and errmsg will be return to capture any error raised by the routine.

3.sqlite3_close(sqlite3*)

This routine closes a database connection previously opened by a call to sqlite3_open(). All prepared statements associated with the connection should be finalized prior to closing the connection.

If any queries remain that have not been finalized, sqlite3_close() will return SQLITE_BUSY with the error message Unable to close due to unfinalized statements.

更多使用例子:

https://www.tutorialspoint.com/sqlite/sqlite_c_cpp.htm

相关推荐
努力努力再努力wz5 分钟前
【C++高阶数据结构系列】:跳表 SkipList 详解:多层索引、随机晋升与C++ 完整实现(附跳表实现的源码)
开发语言·数据结构·数据库·c++·redis·缓存·skiplist
mit6.82412 分钟前
SQLite的优雅设计
sqlite
充值内卷18 分钟前
TauriCPP 基于 WebView2 的轻量级 C++ 桌面应用框架
开发语言·c++
一只小白00022 分钟前
【JVM | 第四篇】—— JVM 内存分配
jvm·面试
枕星而眠25 分钟前
Linux IO多路复用:select、poll、epoll 核心原理与进阶实战
linux·运维·服务器·c++·后端
jjjlike28 分钟前
三款主流AI编程工具实测对比:以C++自研UI引擎项目为测评基准
c++·ai编程
程序喵大人29 分钟前
C++与C语言的核心区别是啥
c语言·开发语言·c++
飞天狗11134 分钟前
2024第十五届蓝桥杯c/c++B组国赛题解
c语言·数据结构·c++·算法·蓝桥杯
梓䈑34 分钟前
C++ AI模型统一接入引擎(第一篇):项目介绍与环境搭建
c++·人工智能·chatgpt
我不是懒洋洋44 分钟前
【C++】内存管理与模板(C++内存管理方式、new和delete的实现原理、malloc/free和new/delete的区别、函数模板、类模板)
c语言·开发语言·c++·青少年编程·visual studio