SQLite3增删改查(C

#include

#include "sqlite3/sqlite3.h"

#pragma comment(lib, "sqlite3/sqlite3.lib")

int main() {

sqlite3* db;

int rc = sqlite3_open("test.db", &db);

if (rc) {

std::cerr << "打开数据库失败: " << sqlite3_errmsg(db) << std::endl;

return 1;

}

复制代码
// 创建表
const char* create_sql = "CREATE TABLE IF NOT EXISTS users ("
	"id INTEGER PRIMARY KEY AUTOINCREMENT,"
	"name TEXT NOT NULL,"
	"age INTEGER);";
rc = sqlite3_exec(db, create_sql, nullptr, nullptr, nullptr);
if (rc != SQLITE_OK) {
	std::cerr << "创建表失败: " << sqlite3_errmsg(db) << std::endl;
	sqlite3_close(db);
	return 1;
}

// 插入测试数据
const char* insert_sql = "INSERT INTO users (name, age) VALUES ('Alice', 30), ('Bob', 25), ('Charlie', 35);";
rc = sqlite3_exec(db, insert_sql, nullptr, nullptr, nullptr);
if (rc != SQLITE_OK) {
	std::cerr << "插入数据失败: " << sqlite3_errmsg(db) << std::endl;
}

// 查看数据
std::cout << "===== 初始数据 =====" << std::endl;
const char* select_sql = "SELECT * FROM users;";
sqlite3_stmt* stmt;
rc = sqlite3_prepare_v2(db, select_sql, -1, &stmt, nullptr);
if (rc == SQLITE_OK) {
	while (sqlite3_step(stmt) == SQLITE_ROW) {
		int id = sqlite3_column_int(stmt, 0);
		const unsigned char* name = sqlite3_column_text(stmt, 1);
		int age = sqlite3_column_int(stmt, 2);
		std::cout << "ID: " << id << ", Name: " << name << ", Age: " << age << std::endl;
	}
	sqlite3_finalize(stmt);
}
else {
	std::cerr << "查询失败: " << sqlite3_errmsg(db) << std::endl;
}

// 更新
const char* update_sql = "UPDATE users SET age = 31 WHERE name = 'Alice';";
rc = sqlite3_exec(db, update_sql, nullptr, nullptr, nullptr);
if (rc != SQLITE_OK) {
	std::cerr << "更新失败: " << sqlite3_errmsg(db) << std::endl;
}
else {
	std::cout << "\n更新成功,影响行数: " << sqlite3_changes(db) << std::endl;
}

// 删除
const char* delete_sql = "DELETE FROM users WHERE name = 'Charlie';";
rc = sqlite3_exec(db, delete_sql, nullptr, nullptr, nullptr);
if (rc != SQLITE_OK) {
	std::cerr << "删除失败: " << sqlite3_errmsg(db) << std::endl;
}
else {
	std::cout << "删除成功,影响行数: " << sqlite3_changes(db) << std::endl;
}

// 再次查看
std::cout << "\n===== 修改后数据 =====" << std::endl;
rc = sqlite3_prepare_v2(db, select_sql, -1, &stmt, nullptr);
if (rc == SQLITE_OK) {
	while (sqlite3_step(stmt) == SQLITE_ROW) {
		int id = sqlite3_column_int(stmt, 0);
		const unsigned char* name = sqlite3_column_text(stmt, 1);
		int age = sqlite3_column_int(stmt, 2);
		std::cout << "ID: " << id << ", Name: " << name << ", Age: " << age << std::endl;
	}
	sqlite3_finalize(stmt);
}
else {
	std::cerr << "查询失败: " << sqlite3_errmsg(db) << std::endl;
}

sqlite3_close(db);
return 0;

}

相关推荐
ClouGence1 小时前
Oracle 数据同步为什么会出现数据不一致?长事务是常被忽略的原因
数据库·后端·oracle
飞将4 小时前
从零实现数据库(2)——HashIndex + IndexManager
数据库
兵慌码乱14 小时前
面向桌面端的资产管理系统分层架构设计与核心模块实现
python·系统架构·sqlite·pyqt5·数据库设计·桌面应用开发·mvc架构
Nturmoils1 天前
订单列表慢查询,先看 WHERE、ORDER BY 和 LIMIT
数据库
博客18001 天前
酷宝的使用方法,超好用的免费界面库,C++、MFC可用
c++·mfc·界面库·库来帮·酷宝
郝学胜_神的一滴1 天前
CMake 026:属性体系精讲、四大作用域全解 & 实战代码落地
c++·cmake
渣波1 天前
拒绝 SQL 焦虑!手把手带你用 NestJS + Prisma + DTO 写出“防弹”级后端代码
javascript·数据库·后端
兵慌码乱2 天前
基于Python+PyQt5+SQLite的药房管理系统实现:事务一致性与界面解耦全流程解析
python·sqlite·信号与槽·pyqt5·数据库设计·桌面应用开发·事务处理
众少成多积小致巨2 天前
JNI (Java Native Interface) 技术手册中文参考指南
android·java·c++
倔强的石头_2 天前
KingbaseES 新版MySQL 兼容版体验:旧版迁移 + 功能实测
数据库