0

0

如何在C++中操作SQLite数据库_SQLite接口使用教程

尼克

尼克

发布时间:2025-06-24 08:31:01

|

779人浏览过

|

来源于php中文网

原创

要在c++++中操作sqlite数据库,需使用sqlite的c api并通过封装简化操作。1. 包含头文件sqlite3.h并建立数据库连接,通过sqlite3_open()函数打开或创建数据库;2. 使用sqlite3_exec()执行sql语句以完成表的创建等操作;3. 对于查询,使用sqlite3_prepare_v2()、sqlite3_step()和sqlite3_finalize()逐行获取结果;4. 使用sqlite3_close()关闭数据库连接;5. 为防止sql注入,应使用参数化查询和sqlite3_bind_*()函数绑定用户输入;6. 处理blob数据时,用sqlite3_bind_blob()插入、sqlite3_column_blob()读取;7. 可通过封装一个c++类来管理数据库连接与操作,提高代码可维护性。

如何在C++中操作SQLite数据库_SQLite接口使用教程

要在C++中操作SQLite数据库,你需要使用SQLite提供的C API,并通过一些封装来简化操作。核心在于理解如何连接数据库、执行SQL语句以及处理查询结果。

如何在C++中操作SQLite数据库_SQLite接口使用教程

解决方案

  1. 包含头文件: 首先,确保你的C++代码包含了SQLite的头文件。通常是 sqlite3.h

    如何在C++中操作SQLite数据库_SQLite接口使用教程
    #include 
    #include 
  2. 连接数据库: 使用 sqlite3_open() 函数连接到SQLite数据库。如果数据库不存在,该函数会创建一个新的数据库。

    立即学习C++免费学习笔记(深入)”;

    如何在C++中操作SQLite数据库_SQLite接口使用教程
    sqlite3 *db;
    int rc = sqlite3_open("mydatabase.db", &db);
    
    if (rc) {
        std::cerr << "Can't open database: " << sqlite3_errmsg(db) << std::endl;
        return -1;
    } else {
        std::cout << "Opened database successfully" << std::endl;
    }
  3. 执行SQL语句: 使用 sqlite3_exec() 函数执行SQL语句。这个函数简单直接,但不太适合处理复杂的查询结果。

    ShopEx助理
    ShopEx助理

    一个类似淘宝助理、ebay助理的客户端程序,用来方便的在本地处理商店数据,并能够在本地商店、网上商店和第三方平台之间实现数据上传下载功能的工具。功能说明如下:1.连接本地商店:您可以使用ShopEx助理连接一个本地安装的商店系统,这样就可以使用助理对本地商店的商品数据进行编辑等操作,并且数据也将存放在本地商店数据库中。默认是选择“本地未安装商店”,本地还未安

    下载
    const char *sql = "CREATE TABLE IF NOT EXISTS COMPANY("  \
                         "ID INT PRIMARY KEY     NOT NULL," \
                         "NAME           TEXT    NOT NULL," \
                         "AGE            INT     NOT NULL," \
                         "ADDRESS        CHAR(50)," \
                         "SALARY         REAL );";
    
    rc = sqlite3_exec(db, sql, 0, 0, 0);
    
    if (rc != SQLITE_OK) {
        std::cerr << "SQL error: " << sqlite3_errmsg(db) << std::endl;
        sqlite3_close(db);
        return -1;
    } else {
        std::cout << "Table created successfully" << std::endl;
    }
  4. 处理查询结果: 对于查询操作,通常使用 sqlite3_prepare_v2(), sqlite3_step(), 和 sqlite3_finalize() 这三个函数。sqlite3_prepare_v2() 用于准备SQL语句,sqlite3_step() 用于执行语句并逐行获取结果,sqlite3_finalize() 用于释放资源。

    const char *sql_select = "SELECT * FROM COMPANY;";
    sqlite3_stmt *stmt;
    
    rc = sqlite3_prepare_v2(db, sql_select, -1, &stmt, 0);
    
    if (rc != SQLITE_OK) {
        std::cerr << "Failed to prepare statement: " << sqlite3_errmsg(db) << std::endl;
        sqlite3_close(db);
        return -1;
    }
    
    while ((rc = 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);
        const unsigned char *address = sqlite3_column_text(stmt, 3);
        double salary = sqlite3_column_double(stmt, 4);
    
        std::cout << "ID = " << id << std::endl;
        std::cout << "Name = " << name << std::endl;
        std::cout << "Age = " << age << std::endl;
        std::cout << "Address = " << address << std::endl;
        std::cout << "Salary = " << salary << std::endl;
        std::cout << "--------------------" << std::endl;
    }
    
    sqlite3_finalize(stmt);
  5. 关闭数据库连接: 使用 sqlite3_close() 函数关闭数据库连接。

    sqlite3_close(db);

如何避免SQL注入攻击?

使用参数化查询是防止SQL注入的关键。不要直接将用户输入拼接到SQL语句中,而是使用占位符,并通过 sqlite3_bind_*() 函数绑定参数。

const char *sql_insert = "INSERT INTO COMPANY (ID, NAME, AGE, ADDRESS, SALARY) VALUES (?, ?, ?, ?, ?);";
sqlite3_stmt *stmt;

rc = sqlite3_prepare_v2(db, sql_insert, -1, &stmt, 0);
if (rc != SQLITE_OK) {
    std::cerr << "Failed to prepare statement: " << sqlite3_errmsg(db) << std::endl;
    sqlite3_close(db);
    return -1;
}

int id = 6;
const char *name = "John Doe";
int age = 30;
const char *address = "Anytown";
double salary = 50000.0;

sqlite3_bind_int(stmt, 1, id);
sqlite3_bind_text(stmt, 2, name, -1, SQLITE_STATIC);
sqlite3_bind_int(stmt, 3, age);
sqlite3_bind_text(stmt, 4, address, -1, SQLITE_STATIC);
sqlite3_bind_double(stmt, 5, salary);

rc = sqlite3_step(stmt);
if (rc != SQLITE_DONE) {
    std::cerr << "Execution failed: " << sqlite3_errmsg(db) << std::endl;
} else {
    std::cout << "Inserted successfully" << std::endl;
}

sqlite3_finalize(stmt);

如何处理SQLite数据库中的BLOB数据?

BLOB (Binary Large Object) 用于存储二进制数据,如图像或文档。在C++中,你可以使用 sqlite3_bind_blob() 插入BLOB数据,并使用 sqlite3_column_blob()sqlite3_column_bytes() 读取BLOB数据。

// 插入BLOB数据
FILE *fp = fopen("image.jpg", "rb");
fseek(fp, 0, SEEK_END);
long fsize = ftell(fp);
fseek(fp, 0, SEEK_SET);  /* same as rewind(f); */

unsigned char *blob_data = (unsigned char*)malloc(fsize + 1);
fread(blob_data, fsize, 1, fp);
fclose(fp);

const char *sql_insert_blob = "INSERT INTO Images (id, data) VALUES (?, ?);";
sqlite3_stmt *stmt;
rc = sqlite3_prepare_v2(db, sql_insert_blob, -1, &stmt, 0);

sqlite3_bind_int(stmt, 1, 1);
sqlite3_bind_blob(stmt, 2, blob_data, fsize, SQLITE_STATIC);

sqlite3_step(stmt);
sqlite3_finalize(stmt);
free(blob_data);

// 读取BLOB数据
const char *sql_select_blob = "SELECT data FROM Images WHERE id = 1;";
rc = sqlite3_prepare_v2(db, sql_select_blob, -1, &stmt, 0);

if (sqlite3_step(stmt) == SQLITE_ROW) {
    const void *blob = sqlite3_column_blob(stmt, 0);
    int bytes = sqlite3_column_bytes(stmt, 0);

    FILE *fp_out = fopen("image_out.jpg", "wb");
    fwrite(blob, 1, bytes, fp_out);
    fclose(fp_out);
}
sqlite3_finalize(stmt);

如何使用C++封装SQLite操作?

为了简化代码并提高可维护性,可以创建一个C++类来封装SQLite操作。这个类可以处理数据库连接、SQL语句执行和结果处理。

#include 
#include 
#include 
#include 

class SQLiteDB {
public:
    SQLiteDB(const std::string& db_path) {
        int rc = sqlite3_open(db_path.c_str(), &db_);
        if (rc) {
            throw std::runtime_error("Can't open database: " + std::string(sqlite3_errmsg(db_)));
        }
    }

    ~SQLiteDB() {
        if (db_) {
            sqlite3_close(db_);
        }
    }

    void execute(const std::string& sql) {
        char *errMsg = 0;
        int rc = sqlite3_exec(db_, sql.c_str(), 0, 0, &errMsg);
        if (rc != SQLITE_OK) {
            std::string errorMsg = "SQL error: " + std::string(errMsg);
            sqlite3_free(errMsg);
            throw std::runtime_error(errorMsg);
        }
    }

    sqlite3* getDB() const {
        return db_;
    }

private:
    sqlite3 *db_ = nullptr;
};

int main() {
    try {
        SQLiteDB db("mydatabase.db");
        db.execute("CREATE TABLE IF NOT EXISTS COMPANY (ID INT PRIMARY KEY NOT NULL, NAME TEXT NOT NULL, AGE INT NOT NULL, ADDRESS CHAR(50), SALARY REAL);");
        db.execute("INSERT INTO COMPANY (ID, NAME, AGE, ADDRESS, SALARY) VALUES (1, 'Paul', 32, 'California', 20000.00 );");

        // 使用db.getDB()来执行更复杂的操作
        sqlite3_stmt *stmt;
        const char *sql_select = "SELECT * FROM COMPANY;";
        int rc = sqlite3_prepare_v2(db.getDB(), sql_select, -1, &stmt, 0);
        // ... (处理查询结果)
        sqlite3_finalize(stmt);

    } catch (const std::runtime_error& e) {
        std::cerr << "Exception: " << e.what() << std::endl;
        return -1;
    }
    return 0;
}

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

675

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

319

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

346

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1084

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

356

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

674

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

566

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

409

2024.04.29

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

65

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

相关下载

更多

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 5.7万人学习

C 教程
C 教程

共75课时 | 3.8万人学习

C++教程
C++教程

共115课时 | 10.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号