SQLite入门(二)读写二进制数据
//读二进制数据的函数
BOOL OpenBinDataFile(BYTE **pBUf,UINT &len)
{
if (pBUf == NULL)
{
return FALSE;
}
std::ifstream fs;
fs.open(g_szBinDataPath,ios::binary);
if (!fs.is_open())
{
cout<<"File:"<<g_szBinDataPath<<"not Open"<<endl;
return FALSE;
}
fs.seekg(0,ios::end);
len = fs.tellg();
fs.seekg(0,ios::beg);
*pBUf = new BYTE[len];
if (NULL == *pBUf)
{
cout<<"内存分配不足"<<endl;
return FALSE;
}
fs.read((char*)(*pBUf),len);
fs.close();
return TRUE;
}
//#define _USE_TRANSACTION //是否使用事务
#define _DB_TABLE_COUNTS 10 //100张表
#define LOOPSCOUNT 20 //记录数
#define TABLEFLAG 10 //第十张表写入1000个记录
#define RESETEST
BOOL SqlitePerfWithUnicode()//Unicode
{
cout<<"UNICODE TEST:"<<endl;
BYTE *pBuf=NULL;
UINT len = 0;
if (!OpenBinDataFile(&pBuf,len))
{
cout<<"打开二进制数据失败"<<endl;
if (pBuf)
{
delete []pBuf;
}
return FALSE;
}
sqlite3 *db = NULL;
TCHAR *errMsg = NULL;
sqlite3_stmt *pstmt=NULL;
TCHAR *psql = NULL;
int nRet = -1,nRows=-1;
nRet = sqlite3_open16(L"F:\\UnicodeTest.db",&db);
if (nRet)
{
wcout<<L"无法打开UnicodeTest数据库:"<<sqlite3_errmsg16(db)<<endl;
//sqlite3_free(errMsg);
sqlite3_close(db);
cin.get();
return 1;
}
else
{
wcout<<L"成功打开UnicodeTest.db"<<endl;
}
TCHAR szNum[100]={0};
TCHAR table[100]={0};
//std::vector<std::wstring> vecTableNames;
std::vector<std::wstring> vecID;
std::wstring wst;
std::vector<std::wstring> vecInsertStr,vecReadStr;
vecInsertStr.reserve(_DB_TABLE_COUNTS);
vecReadStr.reserve(_DB_TABLE_COUNTS);
for (int j=0;j<LOOPSCOUNT*10;++j)
{
_itot(j,szNum,10);
vecID.push_back(szNum);
}
for (int i=0;i<_DB_TABLE_COUNTS;++i)//建立100张表
{
_itot(i,szNum,10);
//vecID.push_back(szNum);//不够
wst = L"unicodetest_";
wst += szNum;//表命名:unicodetest_x
//vecTableNames.push_back(wst);
psql = L"create table if not exists %s(id nchar(20) primary key,name blob)";
_snwprintf_s(table,_countof(table),_TRUNCATE,psql,wst.c_str());
//创建 _DB_TABLE_COUNTS 张表
psql = table;
sqlite3_prepare16(db,psql,-1,&pstmt,NULL);
sqlite3_step(pstmt);
sqlite3_reset(pstmt);
psql = L"insert into %s values(?,?);";
_snwprintf_s(table,_countof(table),_TRUNCATE,psql,wst.c_str());
//psql = table;
vecInsertStr.push_back(table);
psql = L"select id,name from %s;";
_snwprintf_s(table,_countof(table),_TRUNCATE,psql,wst.c_str());
//psql = table;
vecReadStr.push_back(table);
}
//psql = L"create table if not exists unicodetest(id nchar(20) primary key,name blob)";
//sqlite3_prepare16(db,psql,-1,&pstmt,NULL);
//sqlite3_step(pstmt);
//sqlite3_reset(pstmt);
DWORD dwBegin = GetTickCount();
#ifdef _USE_TRANSACTION
sqlite3_exec(db,"begin transaction;",NULL,NULL,NULL);
#endif
for(int j=1;j<_DB_TABLE_COUNTS;++j)
{
psql = const_cast<TCHAR*>(vecInsertStr[j].c_str());
#ifdef RESETEST
sqlite3_prepare16(db,psql,-1,&pstmt,NULL);
#endif
for (int i=0;i<LOOPSCOUNT;++i)//写
{
#ifndef RESETEST
sqlite3_prepare16(db,psql,-1,&pstmt,NULL);
#endif
sqlite3_bind_text16(pstmt,1,vecID[i].c_str(),-1,NULL);
sqlite3_bind_blob(pstmt,2,pBuf,len,NULL);
sqlite3_step(pstmt);
#ifdef RESETEST
sqlite3_reset(pstmt);
#else
sqlite3_finalize(pstmt);
#endif
}
}
psql = const_cast<TCHAR*>(vecInsertStr[0].c_str());//id为"0"的表写入1000个记录
for (int i=0;i<LOOPSCOUNT*10;++i)//写
{
sqlite3_prepare16(db,psql,-1,&pstmt,NULL);
sqlite3_bind_text16(pstmt,1,vecID[i].c_str(),-1,NULL);//这里也相应的扩大
sqlite3_bind_blob(pstmt,2,pBuf,len,NULL);
sqlite3_step(pstmt);
sqlite3_reset(pstmt);
}
#ifdef _USE_TRANSACTION
sqlite3_exec(db,"commit transaction;",NULL,NULL,NULL);
#endif
DWORD dwEnd = GetTickCount();
cout<<"共有 "<< _DB_TABLE_COUNTS <<" 张表,每张表"<<"插入 "<<LOOPSCOUNT<<" 份记录(每份大小["<<len<<"B].)"<<endl;
cout<<"其中最后一张表插入"<<LOOPSCOUNT*10<<"记录"<<endl;
cout<<"总耗时:"<<dwEnd-dwBegin<<endl;
dwBegin = GetTickCount();
#ifdef _USE_TRANSACTION
sqlite3_exec(db,"begin transaction;",NULL,NULL,NULL);
#endif
for (int i=0;i<_DB_TABLE_COUNTS;++i)//读
{
sqlite3_prepare16(db,vecReadStr[i].c_str(),-1,&pstmt,NULL);
nRet = sqlite3_step(pstmt);
while(nRet == SQLITE_ROW)
{
sqlite3_column_text16(pstmt,0);
sqlite3_column_blob(pstmt,1);//数据先不读出
nRet = sqlite3_step(pstmt);
}
sqlite3_reset(pstmt);
}
#ifdef _USE_TRANSACTION
sqlite3_exec(db,"commit transaction;",NULL,NULL,NULL);
#endif
dwEnd = GetTickCount();
cout<<"依次读 "<<_DB_TABLE_COUNTS<<" 张表内的 "<<LOOPSCOUNT<<"份记录,总耗时:"<<dwEnd-dwBegin<<endl;
sqlite3_reset(pstmt);
sqlite3_finalize(pstmt);
sqlite3_close(db);
if (pBuf)
{
delete []pBuf;
}
//cin.get();
return TRUE;
}
SQLite入门(二)读写二进制数据的更多相关文章
- IO流-文本IO\读写二进制数据
文本IO 一.简述 OutputStreamWriter类使用选定的编码方式吧Unicode字符流转换为字节流,InputStreamReader类将包含字节的输入流转为可以产生Unicode字符的读 ...
- DevExpress XtraReports 入门二 创建 data-aware(数据感知) 报表
原文:DevExpress XtraReports 入门二 创建 data-aware(数据感知) 报表 本文只是为了帮助初次接触或是需要DevExpress XtraReports报表的人群使用的, ...
- 背水一战 Windows 10 (89) - 文件系统: 读写文本数据, 读写二进制数据, 读写流数据
[源码下载] 背水一战 Windows 10 (89) - 文件系统: 读写文本数据, 读写二进制数据, 读写流数据 作者:webabcd 介绍背水一战 Windows 10 之 文件系统 读写文本数 ...
- Java读写二进制数据
import java.io.*; import java.time.LocalDate; public class Test { public static void main(String[] a ...
- echart图表控件配置入门(二)常用图表数据动态绑定
上一节 <echart图表控件配置入门(一)>介绍了echarts图表控件的入门配置,使开发人员可以快速搭建出一个静态的图表.但是在实际开发过程这还是不够的,不可能所有的图表控件都是静态数 ...
- Qt里怎么处理二进制数据
Qt里有个专门的类QDataStream就是专门读写二进制数据的, 它与QByteArray搭配在网络编程中有奇效. 来个栗子: // write data QByteArray data; QDat ...
- 重新想象 Windows 8 Store Apps (23) - 文件系统: 文本的读写, 二进制的读写, 流的读写, 最近访问列表和未来访问列表
原文:重新想象 Windows 8 Store Apps (23) - 文件系统: 文本的读写, 二进制的读写, 流的读写, 最近访问列表和未来访问列表 [源码下载] 重新想象 Windows 8 S ...
- SQLite 入门教程(二)创建、修改、删除表 (转)
转于 SQLite 入门教程(二)创建.修改.删除表 一.数据库定义语言 DDL 在关系型数据库中,数据库中的表 Table.视图 View.索引 Index.关系 Relationship 和触发器 ...
- SQLite入门与分析(二)---设计与概念(续)
SQLite入门与分析(二)---设计与概念(续) 写在前面:本节讨论事务,事务是DBMS最核心的技术之一.在计算机科学史上,有三位科学家因在数据库领域的成就而获ACM图灵奖,而其中之一Jim G ...
随机推荐
- linux gpasswd
gpasswd命令 功能:管理组用法:gpasswd[-a user][-d user][-A user,...][-M user,...][-r][-R]groupname参数:-a:添加用户到组- ...
- JS框架设计之加载器所在路径的探知一模块加载系统
1.要加载一个模块,我们需要一个URL作为加载地址,一个script作为加载媒介,但用户在require是都用ID,我们需要一个将ID转换为URL的方法,思路很简单,强加个约定,URL的合成规则是为: ...
- chrome浏览器开发者工具(一)
一.Elements 在Element中主要分两块大的部分:HTML结构面板和操作dom样式.结构.时间的显示面板 二.Network Network是一个监控当前网页所有的http请求的面版,它主体 ...
- ambari-server启动出现Caused by: java.lang.RuntimeException:java.lang.ClassNotFoundEception:com.mysql.jdbc.Driver问题解决办法(图文详解)
不多说,直接上干货! 问题详解 启动ambari-server出现 Caused by: java.lang.RuntimeException:java.lang.ClassNotFoundEcept ...
- javascript正则表达式语法
1. 正则表达式规则 1.1 普通字符 字母.数字.汉字.下划线.以及后边章节中没有特殊定义的标点符号,都是"普通字符".表达式中的普通字符,在匹配一个字符串的时候,匹配与之相同的 ...
- 安装和部署Jenkins
安装和部署Jenkins 环境 操作系统:ubuntu 14.04.4 LTS 下载Jenkins wget https://mirrors.tuna.tsinghua.edu.cn/jenkins/ ...
- WPF获取程序启动路径(StartupPath)
1. 在传统的Winform中获取 可以使用: Application.StartupPath Application.ExecutablePath 很可惜,这些方法,在WPF中都失效啦 2. 在WP ...
- javascript array类型用法
javascript高级编程-Array引用类型用法总结 2016-09-17 | 357 引用类型-Array类型 引用类型是一种数据结构,用于将数据和功能联系起来. 创建对象的方式: ...
- WINDOWS安装mysql5.7.20
MSI安装包链接 http://pan.baidu.com/s/1mhI0SMO 提取密码 gaqu 安装前要把老版本的MYSQL卸载干净 之前用官网的archive免安装版安装一直失败,放弃,用MS ...
- leetcode_787【K 站中转内最便宜的航班】
有 n 个城市通过 m 个航班连接.每个航班都从城市 u 开始,以价格 w 抵达 v. 现在给定所有的城市和航班,以及出发城市 src 和目的地 dst,你的任务是找到从 src 到 dst 最多经过 ...