mark一下
#include "sqlite3.h"#include <windows.h>#pragma comment(lib,"sqlite3.lib")int _tmain(int argc,_TCHAR* argv[]){ char *zErrMsg = 0; int nRet; sqlite3 *db=NulL; nRet = sqlite3_open( "E:\Login Data",&db ); if ( 0 != nRet ) { printf("Open db error %s\n",sqlite3_errmsg(db)); sqlite3_close( db ); } else { printf( "open db success\n" ); } //insert data char strsql[MAX_PATH]; strcpy(strsql,"insert into logins (origin_url,username_value,password_element,signon_realm,ssl_valID,preferred,date_created,blackListed_by_user,scheme) values ('bb','admin','123','fuck',0)"); nRet = sqlite3_exec( db,strsql,&zErrMsg ); if ( 0 != nRet ) { printf("Insert Error:%s",zErrMsg); } else { printf("Insert OK\n"); } //query data int nRow = 0,nColumn = 0; int index,nResult; char **azResult; //二维数组存放結果 strcpy(strsql,"SELECT origin_url,action_url,username_element,password_value,date_created from logins"); nResult = sqlite3_get_table( db,&azResult,&nRow,&nColumn,&zErrMsg ); printf( "row:%d column=%d \n",nRow,nColumn ); printf( "\nThe result of querying is : \n" ); int i,j; if( sqlITE_OK == nResult) { //查询成功 index = nColumn; //前面说过 dbResult 前面第一行数据是字段名称,从 nColumn 索引开始才是真正的数据 printf("查到%d条记录\n",nRow ); for(i = 0; i < nRow ; i++ ) { printf("第 %d 条记录\n",i+1 ); for( j = 0 ; j < nColumn; j++ ) { printf("字段名:%s > 字段值:%s\n",azResult[j],azResult[index]); index++; // dbResult 的字段值是连续的,从第0索引到第 nColumn - 1索引都是字段名称,从第 nColumn 索引开始,后面都是字段值,它把一个二维的表(传统的行列表示法)用一个扁平的形式来表示 } printf("-------\n"); } } //delete data strcpy(strsql,"DELETE FROM logins WHERE username_value='admin'"); nRet = sqlite3_exec( db,&zErrMsg ); if ( 0 != nRet ) { printf("Delete Error:%s",zErrMsg); } else { printf("Delete OK\n"); } //释放azResult 的內存空間 sqlite3_free_table( azResult ); //关闭数据库 sqlite3_close( db ); getchar(); return 0;}总结
以上是内存溢出为你收集整理的sqlite3数据库 *** 作小记全部内容,希望文章能够帮你解决sqlite3数据库 *** 作小记所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)