C++中内存数据库SQLite的使用

1、 下载sqlite文件。

下载网址: http://www.sqlite.org/download.html
SQLite版本为SQLite  3.8.2 ,相关文件如下。
sqlite-dll-win32-x86-3080200.zip:包含sqlite3.def、sqlite3.dll文件。
sqlite-amalgamation-3080200.zip:包含sqlite3.h 文件。
sqlite-shell-win32-x86-3080200.zip:包含sqlite3.exe 文件。

2、 生成sqlite3.lib。
用ref文件和dll文件生成lib文件
命令行输入:
lib /def:sqlite3.def /machine:ix86 
3、 创建测试数据。 
用sqlite3.exe 创建一个测试文件test.db
  1. D:\sqlite>sqlite3.exe test.db  
  2. SQLite version 3.8.2 2013-12-06 14:53:30  
  3. Enter ".help" for instructions  
  4. Enter SQL statements terminated with a ";"  
  5. sqlite> create table user  
  6.    ...> (  
  7.    ...> id integer primary key autoincrement,  
  8.    ...> name varchar(64),  
  9.    ...> age integer  
  10.    ...> );  
  11. sqlite> .quit  
 4、 创建示例工程
创建win32控制台工程SQLiteTest 
sqlite3.h添加到工程 

sqlite3.lib复制到工程文件夹下
工程属性中添加sqlite3.lib库依赖 或者  代码实现: #pragma comment (lib, "lib/sqlite3.lib")
程序代码为:
#include "stdafx.h"
#include "ssqlite3.h"
#include <iostream>  
using namespace std;   
sqlite3 * pDB = NULL;
//#pragma comment (lib, "lib/sqlite3.lib")
 
int _tmain(int argc, _TCHAR* argv[])
{
int nRes = sqlite3_open("D:\\sqlite\\test.db", &pDB);  
if (nRes != SQLITE_OK)  
{  
cout<<"Open database fail: "<<sqlite3_errmsg(pDB);  
}  
        //基本插入
         string strSql = "";  
strSql += "insert into user(name,age)";  
strSql += "values('";  
strSql += nsf;  
strSql += "',";  
strSql += 25;  
strSql += ");";  
char* cErrMsg;  
int nRes = sqlite3_exec(pDB , strSql.c_str() ,0 ,0, &cErrMsg);    
        //基本查询
  
nRes = sqlite3_exec(pDB, "select * from user;", UserResult , 0 , &cErrMsg); 
 
sqlite3_close(pDB);  
getchar();
return 0;
}
static int UserResult(void *NotUsed, int argc, char **argv, char **azColName)  
{  
for(int i = 0 ; i < argc ; i++)  
{  
cout<<azColName[i]<<" = "<<(argv[i] ? argv[i] : "NULL")<<", ";  
}  
cout<<endl;  
return 0;  
}    
//注意 
UserResult(...) 这个函数
编译成功后,将sqlite3.dll复制到SQLiteTest.exe同一目录下,运行SQLiteTest.exe  
运行结果:
id = 1, name = nsf, age = 25,   

5、 SQLite管理工具
可视化工具很多,推荐使用Sqliteman
官网下载地址:http://www.sqliteman.com/ 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
概述FastDB是一个高效率的内存数据库系统,具有实时性能和方便的C++接口。 FastDB并不支持客户端/服务器结构,所有使用FastDB数据库的应用程序都必须运行在同一台主机上。FastDB为具有主导读取访问模式的应用程序作了优化。通过消除数据传输的开销和使用高性能的锁工具实现了查询执行的高速度。数据库文件和使用数据库的每一个应用程序占用的虚拟内存空间相映射。所以查询在应用程序的任务执行,不需要进行任务切换和数据传输。在FastDB,通过原子指令来实现对数据库并发访问的同步,对查询处理几乎不增加任何开销。FastDB假设整个数据库都在当前内存,并且在这个假设的基础上优化查询算法和结构。另外,数据库缓存管理几乎不会给FastDB增加任何开销,同时FastDB也不需要在数据库文件和缓冲池进行数据传送。这就是为什么FastDB比将所有数据放在缓冲池的传统数据库明显速度快的原因。   FastDB支持事务、在线备份和系统崩溃之后的自动恢复。事务提交协议基于一个影子根页算法,对数据库执行原子更新操作。恢复操作执行起来非常快,给关键应用程序提供了高效率。另外,它还取消了事务日志,提高了系统的整体性能,并且能够更加有效地使用系统资源。   FastDB是面向应用程序的数据库使用应用程序的类信息来构建数据库的表。FastDB支持自动系统赋值,只允许你在一个地方——你的应用程序的类,改变它们的值。FastDB为从数据库提取数据提供了一个灵活而方便的接口。使用类似于SQL的语言来书写查询语句。这些非原子字段、嵌套数组、用户自定义类型和方法、直接指向对象内部的指针等后关系性能,简化了数据库应用程序的设计,并且使得它们更加高效。   虽然FastDB的优化是基于整个数据库都存放在机器的物理内存的这个假设上的,我们依然可以将FastDB使用在那些大小超过系统物理内存数据库上。最后,标准操作系统的交换机制将会起作用。但是所有的FastDB的算法和结构的优化都是基于数据存放在内存这个假设上的,所以数据交换的效率不会很高。
SQLite是一种轻量级关系型数据库管理系统,它支持文件数据库内存数据库。以下是使用C++建立SQLite文件数据库内存数据库以及导入导出数据的示例代码: 1. 建立SQLite文件数据库 ```c++ #include <iostream> #include <sqlite3.h> int main() { sqlite3 *db; int rc = sqlite3_open("test.db", &db); // 打开或创建test.db数据库文件 if (rc) { std::cerr << "Can't open database: " << sqlite3_errmsg(db) << std::endl; sqlite3_close(db); return 1; } else { std::cout << "Opened database successfully" << std::endl; sqlite3_close(db); return 0; } } ``` 2. 建立SQLite内存数据库 ```c++ #include <iostream> #include <sqlite3.h> int main() { sqlite3 *db; int rc = sqlite3_open(":memory:", &db); // 打开内存数据库 if (rc) { std::cerr << "Can't open database: " << sqlite3_errmsg(db) << std::endl; sqlite3_close(db); return 1; } else { std::cout << "Opened database successfully" << std::endl; sqlite3_close(db); return 0; } } ``` 3. 导入数据到SQLite文件数据库 ```c++ #include <iostream> #include <fstream> #include <sqlite3.h> int main() { sqlite3 *db; int rc = sqlite3_open("test.db", &db); // 打开或创建test.db数据库文件 if (rc) { std::cerr << "Can't open database: " << sqlite3_errmsg(db) << std::endl; sqlite3_close(db); return 1; } // 导入数据 std::ifstream infile("data.txt"); std::string line; while (std::getline(infile, line)) { std::string sql = "INSERT INTO table_name (column1, column2, ...) VALUES (" + line + ");"; rc = sqlite3_exec(db, sql.c_str(), NULL, NULL, NULL); if (rc != SQLITE_OK) { std::cerr << "SQL error: " << sqlite3_errmsg(db) << std::endl; sqlite3_close(db); return 1; } } sqlite3_close(db); return 0; } ``` 4. 导出数据从SQLite文件数据库 ```c++ #include <iostream> #include <fstream> #include <sqlite3.h> int main() { sqlite3 *db; int rc = sqlite3_open("test.db", &db); // 打开或创建test.db数据库文件 if (rc) { std::cerr << "Can't open database: " << sqlite3_errmsg(db) << std::endl; sqlite3_close(db); return 1; } // 导出数据 std::ofstream outfile("data.txt"); sqlite3_stmt *stmt; rc = sqlite3_prepare_v2(db, "SELECT * FROM table_name", -1, &stmt, NULL); if (rc == SQLITE_OK) { while (sqlite3_step(stmt) == SQLITE_ROW) { std::string data; for (int i = 0; i < sqlite3_column_count(stmt); ++i) { data += std::string(reinterpret_cast<const char*>(sqlite3_column_text(stmt, i))) + ","; } outfile << data.substr(0, data.length() - 1) << std::endl; } } sqlite3_finalize(stmt); sqlite3_close(db); return 0; } ``` 以上代码仅为示例,实际应用需要根据具体情况进行修改。同时需要注意使用sqlite3_exec函数执行SQL语句时,应该避免拼接字符串产生SQL注入等安全问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值