一个C++版本的Sqlite3封装--SmartDb

简介: 一个C++版本的Sqlite3封装--SmartDb

Sqlite是一个非常轻量级的开源数据库,在嵌入式系统中使用的比较多,存储管理数据非常方便,Sqlite库提供的基于C语言的API,用起来也挺简单,但是有一点不太好的就是API使用起来有些繁琐,另外就是不同的场合,代码复用率很低,又要重新写代码,增加了工作量,代码要尽量复用,才有价值。SmartDB对sqlite做了一层封装(基于C++11的模板元编程),屏蔽了诸多细节,使得我们使用起来很方便。在注重易用性的基础上还兼顾了性能和灵活性。


SmartDb是《深入应用C++11  代码优化与工程级应用》的作者编写的,SmartDb使用了很多C++11新特性:可变长参数、模板元编程、完美转发、泛型编程等,代码质量非常高,很值得学习,使用C++做开发的同学不妨看看,网上有电子版的。


使用这个SmartDb去操作数据库就简单多了:


来看下示例代码:

void TestPerformance()
{
    SmartDB db;
    db.Open("test.db");   //打开数据库
    const string sqlcreat = "CREATE TABLE if not exists TestInfoTable(ID INTEGER NOT NULL, KPIID INTEGER, CODE INTEGER, V1 INTEGER, V2 INTEGER, V3 REAL, V4 TEXT);";
    if (!db.Excecute(sqlcreat))  //执行sql语句
        return;
 
    boost::timer t;
    const string sqlinsert = "INSERT INTO TestInfoTable(ID, KPIID, CODE, V1, V2, V3, V4) VALUES(?, ?, ?, ?, ?, ?, ?);";
    bool ret = db.Prepare(sqlinsert);
    db.Begin();
    for (size_t i = 0; i < 10; i++) //00000
    {
        ret = db.ExcecuteArgs(i, i, i, i, i, i + 1.25, "it is a test");
        if (!ret)
            break;
    }
 
    if (ret)
        db.Commit(); //提交事务
    else
        db.RollBack(); //回滚
 
    cout << t.elapsed() << endl;
    t.restart();
    //100w 3.5-4秒左右
 
    auto p = db.Query("select * from TestInfoTable");
    cout << t.elapsed() << endl;
    cout << "size: " << p->Size() << endl;
    //100W 4秒左右
 
      rapidjson::StringBuffer buffer;
      rapidjson::PrettyWriter<rapidjson::StringBuffer> pretty_writer(buffer);  //PrettyWriter是格式化的json,如果是Writer则是换行空格压缩后的json
      p->Accept(pretty_writer);
      //打印到屏幕
      //cout<<"the json output:"<<endl;
     cout<<buffer.GetString()<<endl;
 
    //遍历查询结果
    rapidjson::Value& infoArray  = *p;
    for ( int i = 0; i < p->Size(); ++i )
    {
        const rapidjson::Value& object = infoArray[i];
        printf("%d. Id: %d  KpiId: %d, v3: %f, v4: %s\n",i,
            object["ID"].GetInt(), object["KPIID"].GetInt(),object["V3"].GetDouble(),object["V4"].GetString());
    }
 
}

查询的数据库时,结果是以Json格式返回的,这里返回的是一个json数组,这个用起来很方便。


作者的源代码是VS下编译测试的,我在VS2015下可以编译运行,在Linux下编译有点问题,可能是编译器的差异造成的,目前只编译通过部分,ExcecuteTuple接口还用不了,Variant的Visit接口编译不通过,注释掉可以通过,这这里好像也没有用到;


大家如果在Linux下编译通过,正常运行告诉我下哈。


在linux下编译通过的版本(码云地址):https://gitee.com/fensw/SmartDB


作者原文:

https://www.cnblogs.com/qicosmos/p/3805156.html


目录
相关文章
|
7月前
|
Linux 数据库管理 Python
CentOS7编译安装Python3.10(含OpenSSL1.1.1安装),创建虚拟环境,运行Django项目(含sqlite版本报错)
CentOS7编译安装Python3.10(含OpenSSL1.1.1安装),创建虚拟环境,运行Django项目(含sqlite版本报错)
836 4
|
3月前
|
Linux 编译器 测试技术
【C++】CentOS环境搭建-快速升级G++版本
通过上述任一方法,您都可以在CentOS环境中高效地升级G++至所需的最新版本,进而利用C++的新特性,提升开发效率和代码质量。
212 64
|
3月前
|
Linux 编译器 测试技术
【C++】CentOS环境搭建-快速升级G++版本
通过上述任一方法,您都可以在CentOS环境中高效地升级G++至所需的最新版本,进而利用C++的新特性,提升开发效率和代码质量。
271 63
|
8月前
|
C++
C++中的封装、继承与多态:深入理解与应用
C++中的封装、继承与多态:深入理解与应用
178 1
|
7月前
|
缓存 网络协议 Linux
c++实战篇(三) ——对socket通讯服务端与客户端的封装
c++实战篇(三) ——对socket通讯服务端与客户端的封装
160 0
|
4月前
|
数据安全/隐私保护 C语言 C++
C++(七)封装
本文档详细介绍了C++封装的概念及其应用。封装通过权限控制对外提供接口并隐藏内部数据,增强代码的安全性和可维护性。文档首先解释了`class`中的权限修饰符(`public`、`private`、`protected`)的作用,并通过示例展示了如何使用封装实现栈结构。接着介绍了构造器和析构器的使用方法,包括初始化列表的引入以及它们在内存管理和对象生命周期中的重要性。最后,通过分文件编程的方式展示了如何将类定义和实现分离,提高代码的模块化和复用性。
|
6月前
|
C++ 容器
【C++】map和set封装
【C++】map和set封装
47 2
|
5月前
|
缓存 C++ Windows
Inno setup 脚本判断 Microsoft Visual C++ Redistributable 不同版本区别
Inno setup 脚本判断 Microsoft Visual C++ Redistributable 不同版本区别
|
6月前
|
存储 开发框架 Java
|
7月前
|
存储 Java C#
C++语言模板类对原生指针的封装与模拟
C++|智能指针的智能性和指针性:模板类对原生指针的封装与模拟