VC下如何使用sqlite?语法方面,资料当然找到.但怎样在VC环境下操作sqlite的数据库呢?
解决方案 »
- CString CListCtrl::GetItemText()函数,如何保证返回的CString的buffer足够?
- 保存DC内容时有菜单的残影
- vc显示和隐藏窗口
- 定时器
- VC# 窗口应用程序 怎么用filesystemwatcher??
- 哪里有真彩色工具条制作工具啊??
- FLASH控件右键菜单如何在VC里屏蔽掉不让它显示啊?我弄了好久都不行,帮帮忙~多谢~
- CFontDialog类出现非法操作该怎么处理?
- 请教:Win2000 Server的dcomcnfg中的那些“应用程序”选项是不是专指进程外组件服务器?立即结帐,谢谢!
- 哪位大侠可以介绍一本串行通讯的好书?
- 在用backspace删除文本的时候,当光标移到了最最左边,如何实现将光标回退到上一行字符末尾?
- vc++6.0中控件the ActiveX control cannot be instantiated
{
#include "sqlite3.h"
};//sqlite3的回调函数// sqlite 每查到一条记录,就调用一次这个回调int LoadMyInfo( void * para, int n_column, char ** column_value, char ** column_name ){//para是你在 sqlite3_exec 里传入的 void * 参数//通过para参数,你可以传入一些特殊的指针(比如类指针、结构指针),然后在这里面强制转换成对应的类型(这里面是void*类型,必须强制转换成你的类型才可用)。然后操作这些数据
//n_column是这一条记录有多少个字段 (即这条记录有多少列)
// char ** column_value 是个关键值,查出来的数据都保存在这里,它实际上是个1维数组(不要以为是2维数组),每一个元素都是一个 char * 值,是一个字段内容(用字符串来表示,以\0结尾)
//char ** column_name 跟 column_value是对应的,表示这个字段的字段名称//这里,我不使用 para 参数。忽略它的存在.
int i;
printf( "记录包含 %d 个字段\n", n_column );for( i = 0 ; i < n_column; i ++ )
{
printf( "字段名:%s ?> 字段值:%s\n", column_name[i], column_value[i] );
}printf( "------------------\n" );
return 0;
}int _tmain(int argc, _TCHAR* argv[])
{
sqlite3 * db = NULL; //声明sqlite关键结构指针int result;//打开数据库
//需要传入 db 这个指针的指针,因为 sqlite3_open 函数要为这个指针分配内存,还要让db指针指向这个内存区
result = sqlite3_open("D:\\Projects\\demo\\SQLiteDemo\\wwxSQLite.db", &db );
if( result != SQLITE_OK )
{
//数据库打开失败
return -1;
}//数据库操作代码
//创建一个测试表,表名叫 MyTable_1,有2个字段: ID 和 name。其中ID是一个自动增加的类型,以后insert时可以不去指定这个字段,它会自己从0开始增加
char * errmsg = NULL;
result = sqlite3_exec( db, "create table MyTable_2( ID integer primary key autoincrement, name nvarchar(32) , translate nvarchar(1024))", NULL, NULL, &errmsg );
if(result != SQLITE_OK)
{
printf( "创建表失败,错误码:%d,错误原因:%s\n", result, errmsg );
}//插入一些记录
result = sqlite3_exec( db, "insert into MyTable_2( name, translate) values ( '走路', 'haha')", 0, 0, &errmsg );
if(result != SQLITE_OK )
{
printf( "插入记录失败,错误码:%d,错误原因:%s\n", result, errmsg );
}result = sqlite3_exec( db, "insert into MyTable_2( name,translate) values ( '骑单车', 'hello' )", 0, 0, &errmsg );
if(result != SQLITE_OK )
{
printf( "插入记录失败,错误码:%d,错误原因:%s\n", result, errmsg );
}result = sqlite3_exec( db, "insert into MyTable_2( name,translate ) values ( '坐汽车', 'good')", 0, 0, &errmsg );
if(result != SQLITE_OK )
{
printf( "插入记录失败,错误码:%d,错误原因:%s\n", result, &errmsg );
}//开始查询数据库,这里使用回调函数查询
result = sqlite3_exec( db, "select * from MyTable_2", LoadMyInfo, NULL, &errmsg );//下面使用sqlite3_get_table //开始查询,传入的 dbResult 已经是 char **,这里又加了一个 & 取地址符,传递进去的就成了 char ***
char ** dbResult;
int nRow,nColumn;
int index;
result = sqlite3_get_table( db, "select * from MyTable_2", &dbResult, &nRow, &nColumn, &errmsg );if( SQLITE_OK == result )
{
//查询成功
index = nColumn; //前面说过 dbResult 前面第一行数据是字段名称,从 nColumn 索引开始才是真正的数据
printf( "查到%d条记录\n", nRow );for(int i = 0; i < nRow ; i++ )
{
printf( "第 %d 条记录\n", i+1 );
for(int j = 0 ; j < nColumn; j++ )
{
printf( "字段名:%s ?> 字段值:%s\n", dbResult[j], dbResult [index] );
++index; // dbResult 的字段值是连续的,从第0索引到第 nColumn - 1索引都是字段名称,从第 nColumn 索引开始,后面都是字段值,它把一个二维的表(传统的行列表示法)用一个扁平的形式来表示
}
printf( "-------\n" );
}
}//到这里,不论数据库查询是否成功,都释放 char** 查询结果,使用 sqlite 提供的功能来释放
sqlite3_free_table( dbResult );//关闭数据库
sqlite3_close( db );system("PAUSE");
return 0;
}
VC2005使用SQLite,适用于WIN32以及WINCEhttp://www.sqlite.com.cn/MySqlite/4/494.HtmlC/C++中调用SQLITE3的基本步骤http://www.sqlite.com.cn/MySqlite/6/512.Html