在C++项目中使用SQLite3数据库的全过程

 更新时间:2025年11月03日 09:35:54   作者:Humbunklung  
本文档介绍如何在 C++ 项目中使用 SQLite3 数据库,假设通过 vcpkg 安装了 SQLite3,因本机为Windows环境,为方便,用了本机的Visual Studio 2022 创建cmake项目,需要的朋友可以参考下

安装 SQLite3

首先,确保你已经通过 vcpkg 安装了 SQLite3。可以使用以下命令进行安装:

vcpkg install sqlite3

配置 CMakes

在 CMakeLists.txt 文件中,添加以下内容以找到并链接 SQLite3:

find_package(SQLite3 REQUIRED)

target_link_libraries(your_target PRIVATE SQLite::SQLite3)

实际上,由于我用了Visual Studio 2022,我的cmake项目结构如下:

use-sqlite3目录下的CMakeLists.txt文件我修改如下:

# CMakeList.txt: use-sqlite3 的 CMake 项目,在此处包括源代码并定义
# 项目特定的逻辑。
#
SET(CMAKE_TOOLCHAIN_FILE "D:/tools/vcpkg/scripts/buildsystems/vcpkg.cmake")
include("D:/tools/vcpkg/scripts/buildsystems/vcpkg.cmake")
if(DEFINED ENV{VCPKG_DEFAULT_TRIPLET} AND NOT DEFINED VCPKG_TARGET_TRIPLET)
    set(VCPKG_TARGET_TRIPLET "$ENV{VCPKG_DEFAULT_TRIPLET}" CACHE STRING "" FORCE)
endif()
# 将源代码添加到此项目的可执行文件。
add_executable (use-sqlite3 "use-sqlite3.cpp" "use-sqlite3.h")

if (CMAKE_VERSION VERSION_GREATER 3.12)
  set_property(TARGET use-sqlite3 PROPERTY CXX_STANDARD 20)
endif()

# TODO: 如有需要,请添加测试并安装目标。

find_package(SQLite3 REQUIRED)

target_link_libraries(use-sqlite3 PRIVATE SQLite::SQLite3)

使用 SQLite3

在你的 C++ 代码中,可以包含 SQLite3 的头文件并开始使用它:

// 示例代码

// use-sqlite3.cpp: 定义应用程序的入口点。
//

#include "use-sqlite3.h"
#include "sqlite3.h"

using namespace std;

int main()
{
	sqlite3* db;
	char* zErrMsg = 0;
	int rc;

	// 打开数据库
	rc = sqlite3_open("example.db", &db);
	if (rc) {
		std::cerr << "Can't open database: " << sqlite3_errmsg(db) << std::endl;
		return(0);
	}
	else {
		std::cout << "Opened database successfully" << std::endl;
	}

	// 创建表
	const char* sqlCreateTable = "CREATE TABLE IF NOT EXISTS test( "
		"id INTEGER PRIMARY KEY, "
		"name TEXT NOT NULL);";
	rc = sqlite3_exec(db, sqlCreateTable, 0, 0, &zErrMsg);
	if (rc != SQLITE_OK) {
		std::cerr << "SQL error: " << zErrMsg << std::endl;
		sqlite3_free(zErrMsg);
	}
	else {
		std::cout << "Table created successfully" << std::endl;
	}

	// 插入数据
	const char* sqlInsert = "INSERT INTO test(name) VALUES ('Alice');";
	rc = sqlite3_exec(db, sqlInsert, 0, 0, &zErrMsg);
	if (rc != SQLITE_OK) {
		std::cerr << "SQL error: " << zErrMsg << std::endl;
		sqlite3_free(zErrMsg);
	}
	else {
		std::cout << "Records created successfully" << std::endl;
	}

	const char* sqlUpdate = "UPDATE test SET name = 'Bob' WHERE id = 2;";
	rc = sqlite3_exec(db, sqlUpdate, 0, 0, &zErrMsg);
	if (rc != SQLITE_OK) {
		std::cerr << "SQL error: " << zErrMsg << std::endl;
		sqlite3_free(zErrMsg);
	}
	else {
		std::cout << "Record updated successfully" << std::endl;
	}

	// 查询数据
	const char* sqlSelect = "SELECT * FROM test;";
	rc = sqlite3_exec(db, sqlSelect, [](void* NotUsed, int argc, char** argv, char** azColName) {
		for (int i = 0; i < argc; i++) {
			std::cout << azColName[i] << " = " << (argv[i] ? argv[i] : "NULL") << std::endl;
		}
		std::cout << std::endl;
		return 0;
		}, 0, &zErrMsg);
	if (rc != SQLITE_OK) {
		std::cerr << "SQL error: " << zErrMsg << std::endl;
		sqlite3_free(zErrMsg);
	}
	else {
		std::cout << "Operation done successfully" << std::endl;
	}

	// 关闭数据库
	sqlite3_close(db);
	std::cout << "Database closed successfully" << std::endl;

	return 0;
}

运行效果如下:

到此这篇关于在C++项目中使用SQLite3数据库的全过程的文章就介绍到这了,更多相关C++使用SQLite3数据库内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • C语言中的abs()函数和exp()函数的用法

    C语言中的abs()函数和exp()函数的用法

    这篇文章主要介绍了C语言中的abs()函数和exp()函数的用法,是C语言入门学习中的基础知识,需要的朋友可以参考下
    2015-08-08
  • C++ 中的异常抛出和捕获方式

    C++ 中的异常抛出和捕获方式

    这篇文章主要介绍了C++ 中的异常抛出和捕获方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-07-07
  • C++之Primer类型转换方式

    C++之Primer类型转换方式

    这篇文章主要介绍了C++之Primer类型转换方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2025-03-03
  • C语言中的数组指针数组与函数指针数组

    C语言中的数组指针数组与函数指针数组

    数组指针数组和函数指针数组是两个强大但容易混淆的概念,下面就来介绍一下C语言中的数组指针数组与函数指针数组的区别,具有一定的参考价值,感兴趣的可以了解一下
    2025-06-06
  • C++ 读文件 将文件内容读入到字符串string中的方法

    C++ 读文件 将文件内容读入到字符串string中的方法

    今天小编就为大家分享一篇C++ 读文件 将文件内容读入到字符串string中的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-07-07
  • C语言实现万年历源码

    C语言实现万年历源码

    这篇文章主要为大家详细介绍了C语言实现万年历源码,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-10-10
  • c++二叉树的几种遍历算法

    c++二叉树的几种遍历算法

    c++二叉树的几种遍历算法,需要的朋友可以参考一下
    2013-02-02
  • QT中QChart绘制折线图

    QT中QChart绘制折线图

    本文主要介绍了QChart绘制折线图,Qt Charts基于Qt的Graphics View架构,其核心组件是QChartView 和 QChart,感兴趣的可以了解一下
    2022-04-04
  • C++ 中assert()函数用法总结

    C++ 中assert()函数用法总结

    这篇文章主要介绍了C++ 中assert()函数用法总结的相关资料,需要的朋友可以参考下
    2017-07-07
  • C语言实现打印杨辉三角的方法详细(三种方法)

    C语言实现打印杨辉三角的方法详细(三种方法)

    杨辉三角是中国古代数学的杰出研究成果之一,它把二项式系数图形化,把组合数内在的一些代数性质直观地从图形中体现出来,是一种离散型的数与形的结合。本文将介绍三种可以实现打印杨辉三角的办法,感兴趣的可以试一试
    2022-01-01

最新评论