MFC之sqlite
引用头文件和将生成的SQLite.dll加载到项目中
#include "sqlite3.h"
1.动态加载sqlite
//***********************数据库动态加载*****************************//
typedef int (SQLITE_STDCALL *psqlite3_open)(
const char *filename, /* Database filename (UTF-8) */
sqlite3 **ppDb /* OUT: SQLite db handle */
); typedef int (SQLITE_STDCALL *psqlite3_get_table)(
sqlite3 *db, /* An open database */
const char *zSql, /* SQL to be evaluated */
char ***pazResult, /* Results of the query */
int *pnRow, /* Number of result rows written here */
int *pnColumn, /* Number of result columns written here */
char **pzErrmsg /* Error msg written here */
);
typedef void (SQLITE_STDCALL *psqlite3_free_table)(char **result); typedef int (SQLITE_STDCALL *psqlite3_exec)(
sqlite3*, /* An open database */
const char *sql, /* SQL to be evaluated */
int (*callback)(void*,int,char**,char**), /* Callback function */
void *, /* 1st argument to callback */
char **errmsg /* Error msg written here */
); typedef void (SQLITE_STDCALL *psqlite3_free)(void*); typedef int (SQLITE_STDCALL *psqlite3_close)(sqlite3*); psqlite3_open sql_open=NULL;
psqlite3_exec sql_exec=NULL;
psqlite3_close sql_close=NULL;
psqlite3_get_table sql_get_table=NULL;
psqlite3_free_table sql_free_table=NULL;
psqlite3_free sql_free=NULL;
2.转换函数
HINSTANCE hInst=LoadLibrary(L"\\NANDFlash\\SQLite.dll");//动态加载Dll
sql_open=(psqlite3_open)GetProcAddress(hInst, _T("sqlite3_open"));
sql_exec=(psqlite3_exec)GetProcAddress(hInst, _T("sqlite3_exec"));
sql_close=(psqlite3_close)GetProcAddress(hInst, _T("sqlite3_close"));
sql_get_table=(psqlite3_get_table)GetProcAddress(hInst, _T("sqlite3_get_table"));
sql_free_table=(psqlite3_free_table)GetProcAddress(hInst, _T("sqlite3_free_table"));
sql_free=(psqlite3_free)GetProcAddress(hInst, _T("sqlite3_free"));
3.使用
//读取裂纹数据库文件并保存到裂纹数组中 sqlite3 * db = NULL; //声明sqlite关键结构指针
int result;
// 打开或创建数据库
result = sql_open("\\NANDFlash\\sqlite.db", &db );
if( result != SQLITE_OK )
{
//数据库打开失败
return -1;
} char **dbResult;
int nRow, nColumn;
char * errmsg = NULL; //查找 LiewenMes 表是否已有
sql_get_table(db, "SELECT * FROM sqlite_master where type='table' and name='LiewenMes'", &dbResult, &nRow, &nColumn, NULL);
if(nRow>0)
{
// 表已经存在,查询数据表
const char * sSQL3 = "select * from LiewenMes;";
// 不用回调函数的查询
char **dbResult1;
if(SQLITE_OK == sql_get_table( db, sSQL3, &dbResult1, &nRow, &nColumn, &errmsg ))
{
//dbResult1 前面第一行数据是字段名称,从 nColumn 索引开始才是真正的数据
// dbResult1 的字段值是连续的,从第0索引到第 nColumn - 1索引都是字段名称,从第 nColumn 索引开始,
//后面都是字段值,它把一个二维的表(传统的行列表示法)用一个扁平的形式来表示 int index = nColumn;
num_liewen=0;//裂纹个数置0
for(int i = 1; i <= nRow ; i++)
{ lw_jc_bianhao[num_liewen]=dbResult1[index++];
lw_cgq_bianhao[num_liewen]=dbResult1[index++];
lw_cgq_id[num_liewen]=dbResult1[index++];
lw_cgq_weizhi[num_liewen]=dbResult1[index++];
lw_weizhi[num_liewen]=dbResult1[index++];
lw_ry_name[num_liewen]=dbResult1[index++];
lw_cgq_date[num_liewen]=dbResult1[index++]; num_liewen++;
}
}
//不论数据库查询是否成功,都释放 char** 查询结果,使用 sqlite 提供的功能来释放
sql_free_table( dbResult1 );
}else{
// 执行建表SQL const char * sSQL1 ="create table LiewenMes(liewen_jc_bianhao nvarchar(32),liewen_cgi_bianhao nvarchar(32),liewen_cgq_id nvarchar(50),liewen_cgq_locate nvarchar(32),liewen_lw_locate nvarchar(32),liewen_ry_name nvarchar(32),date_now DATETIME)";
result = sql_exec( db,sSQL1,0, 0, &errmsg ); if(result != SQLITE_OK )
{
printf("创建表失败,错误码:%d,错误原因:%s\n", result, errmsg );
sql_free(errmsg);
} }
sql_free_table( dbResult ); // 关闭数据库
sql_close( db );
db=0;
4.将 按照(http://blog.csdn.net/educast/article/details/8263468)制作的SQLite.lib SQLite.dll拷贝到wince系统的运行目录的路径下,即:\\NANDFlash\\
MFC之sqlite的更多相关文章
- MFC使用SQLite 学习系列 一: SQLITE_MISUSE错误
一 为什么要选择SQLite 由于使用文本文件来记录测试数据,速度越来越慢的问题,经过园友推荐,使用了SQLite来进行数据的存储,再次感谢园友@LightSmaile. 关于这个问题,可以参考一下上 ...
- MFC中SQLite数据库的使用
1打开数据库 BOOL playDlg::openData() { WCHAR a[100]; CString path; path = m_exePath+L"sentence_makin ...
- MFC使用SQLite 学习系列 二:无法容忍的数据插入效率
上一篇随笔中,介绍了,基本的使用没什么问题了,那么开始数据的插入. 一 问题--无法容忍的插入效率 代码写入基本完成,然后开始测试.起初,插入数据的时候基本上是插入每次插入9组数据,看不出来数据插入的 ...
- sqlite与C++进行连接
SQLite数据库是零配置的,sqlite数据库不同于SqlServer等数据库,SQLite不需要复杂配置,只需要,将SQLite的库文件和动态链接文件拷贝到相应工程目录下,就可以使用SQLite数 ...
- SQLite安装、编译与应用
什么是 SQLite SQLite是一款轻量级的.基于文件的嵌入式数据库,实现自包容.零配置.支持事务的SQL数据库引擎.与其他数据库管理系统不同,SQLite 的安装和运行非常简单,在大多数情况下, ...
- C++ 使用SQLite
1.SQLite是一个完全独立的.不需要服务器.不要任何配置.支持SQL的.开源的文件数据库引擎.源代码和支持可以登录:http://www.sqlite.org/ 1.1.下载sqlite3.d ...
- 在MFC中支持sqlite3
在vc环境下支持sqlite3的方法有很多,sqlite官网也有推荐sqlitewrappers列表,我选用的是CppSqlite 建立MFC工程的步骤我就不赘述了,以下操作均假设你已经创建好了一个M ...
- VC++、MFC Sqlite3数据库的使用
SQLite数据库是一种本地的轻型数据库,在存储一些本地的数据的时候,或者不需要用到Oracle,SQL2008之类的大型数据库的时候,Sqlite的优势就能够得到发挥.程序需要采集数据存储起来,可以 ...
- MFC小程序------01 代码管理器
1.代码入库: 2.代码查找: 3.查看全部代码: 4.程序设置: 自己学习MFC写的一个小程序,当中还有很多功能还待完好,比方数据库的导入功能还没有写,但导出功能是能够用的,查找算法也不是非常好,还 ...
随机推荐
- vim选中多行缩进(python多行缩进)与删除多行前面的空格
最近用vim写python,有时候会在一段代码前面套一个循环的操作,这个时候将这一段代码整体向后平移四个空格,来满足vim缩进的要求,如何做到这一点呢? 1. ESC之后,ctrl+v进入多行行首选中 ...
- [CSL 的字符串][栈,模拟]
链接:https://ac.nowcoder.com/acm/contest/551/D来源:牛客网题目描述 CSL 以前不会字符串算法,经过一年的训练,他还是不会……于是他打算向你求助. 给定一个字 ...
- Linux服务安装配置总结
- 【SpringBoot】息队列介绍和SpringBoot2.x整合RockketMQ、ActiveMQ
========================13.消息队列介绍和SpringBoot2.x整合RockketMQ.ActiveMQ ======================= 1.JMS介绍和 ...
- 随机数的组合问题(JavaScript描述)
随机数的组合问题在面试时是经常考的,比如之前我就被问到:“有一个可以生成1-5的随机数函数,怎样把它扩大到1-7?” 在解决这个问题之前,先来看看另外一个比较简单的问题:“有一个可以生成1-7的函数, ...
- 代码回滚:Reset、Checkout、Revert的选择
代码回滚:Reset.Checkout.Revert的选择 Git仓库有三个主要组成——工作目录,缓存区和提交历史. 从图中我们可以看出,缓存区或者叫索引,其实是指一整套即将被下一个提交的文件集合.也 ...
- Azure VMSS (1) 入门
<Windows Azure Platform 系列文章目录> 在使用云计算服务的时候,我们经常需要有自动横向扩展的功能.比如: 1.在业务高峰期,根据负载的增加,自动打开若干台VM 2. ...
- win10系统IE浏览器中无法显示Java国际化的问题
http://jingyan.baidu.com/article/656db918e37914e381249c9f.html?qq-pf-to=pcqq.c2c 自从装上Win10系统后,跟随前些IE ...
- 2017-07-06 eclipse在线安装SVN1.9插件
1,百度搜索subeclipse,点击第一个: 2,官网说,文档已移动到github wiki上: 3,打开github wiki,复制最新发布版本地址: 4,在eclipse里面,打开help-&g ...
- finstrument-functions
2017-12-03 23:59:16 参考 如何快速地在每个函数入口处加入相同的语句? https://www.zhihu.com/question/56132218 做个存档 scj@scjCom ...