VS2013 Sqlite3 操作指令
- extern "C"{
- #include "sqlite3.h"
- };
- #pragma comment(lib,"sqlite.lib")
- /*
- 为什么要 extern “C” ?这是C++的基础。要在 C++里使用一段 C 的代码,必须要用 extern “C” 括起来。C++跟 C虽然语法上有重叠,但是它们是两个不同的东西,内存里的布局是完全不同的,在C++编译器里不用extern “C”括起C代码,会导致编译器不知道该如何为 C 代码描述内存布局。可能在 sqlite3.c 里人家已经把整段代码都 extern “C” 括起来了,但是你遇到一个.c 文件就自觉的再括一次,也没什么不好。
- */
- //-----------------------------------------------------OK,尽情的爽吧---------------------------------------------------//
- 下载是我简单作用sqlite3的代码,不好看,请包涵!
- 详细教程在这:http://download.csdn.net/detail/q775968375/5970059
- void CMySqliteDlg::OnBnClickedOk()
- {
- // TODO: 在此添加控件通知处理程序代码
- //CDialogEx::OnOK();
- CTime m_time;
- m_time=CTime::GetCurrentTime();//获取当前时间日期
- FILE *fp=fopen("debug.txt","a+");
- fprintf(fp,"\n------------------------%s------------------------\n"
- ,m_time.Format(_T("%Y-%m-%d %H:%M:%S %A")));
- ::sqlite3 *db=NULL;
- ::sqlite3_stmt *stmt;
- char *sql=NULL,*error=NULL;
- const char *tail=NULL;
- int res;
- res=::sqlite3_open("MySqlite.db",&db);//打开数据库(不存在创建)
- if(res!=SQLITE_OK){
- ::sqlite3_close(db);
- fprintf(fp,"open database is failure:%s\n",::sqlite3_errmsg(db));
- return;
- }else fprintf(fp,"open database is success!\n");
- //create table
- sql="create table if not exists MyTable(Row integer primary key autoincrement,Content text)";
- res=::sqlite3_exec(db,sql,NULL,NULL,&error);
- if(res!=SQLITE_OK){
- ::sqlite3_close(db);
- fprintf(fp,"error create table:%s %s\n",error,::sqlite3_errmsg(db));
- return;
- }else fprintf(fp,"table is created\n");
- //insert
- sql="insert or replace into MyTable(Row,Content) values(?,?)";
- //sqlite3_prepare_v2的作用是将UTF-8格式的SQL语句转换为编译后的语句,并返回指向该语句的指针
- res=::sqlite3_prepare_v2(db,sql,-1,&stmt,&tail);
- if(res!=SQLITE_OK){
- ::sqlite3_close(db);
- fprintf(fp,"insert is failure:%s %s\n",tail,::sqlite3_errmsg(db));
- return;
- }
- for(int i=0;i<3;i++){
- //::sqlite3_bind_int(stmt,1,0);//1:id 2:data
- ::sqlite3_bind_text(stmt,2,"数据库数据",-1,NULL);
- if(::sqlite3_step(stmt)!=SQLITE_DONE){
- fprintf(fp,"error update table:%s\n",::sqlite3_errmsg(db));
- }
- ::sqlite3_reset(stmt); //重新初始化该sqlite3_stmt对象绑定的变量。
- }
- ::sqlite3_finalize(stmt);
- //delete
- sql="delete from MyTable where Row=2";
- //res=::sqlite3_prepare_v2(db,sql,-1,&stmt,&tail);
- res=::sqlite3_exec(db,sql,NULL,NULL,&error);
- if(res!=SQLITE_OK){
- ::sqlite3_close(db);
- fprintf(fp,"delete error:%s %s\n",error,::sqlite3_errmsg(db));
- return;
- }else fprintf(fp,"delete is success\n");
- ::sqlite3_finalize(stmt);
- //update
- sql="update MyTable set Content='修改后的数据' where Row=3";
- res=::sqlite3_exec(db,sql,NULL,NULL,&error);
- if(res!=SQLITE_OK){
- ::sqlite3_close(db);
- fprintf(fp,"update error:%s %s\n",error,::sqlite3_errmsg(db));
- return;
- }else fprintf(fp,"update is success\n");
- ::sqlite3_finalize(stmt);
- //query
- sql="select Row,Content from MyTable order by Row";
- res=::sqlite3_prepare_v2(db,sql,-1,&stmt,&tail);
- if(res!=SQLITE_OK){
- ::sqlite3_close(db);
- fprintf(fp,"query is failure:%s %s\n",tail,::sqlite3_errmsg(db));
- return;
- }
- while(::sqlite3_step(stmt)==SQLITE_ROW){
- static int cnt=::sqlite3_column_count(stmt);
- for(int i=0;i<cnt;i++){
- fprintf(fp,"Data:%s\n",::sqlite3_column_text(stmt,i));
- }
- /*
- int row=::sqlite3_column_int(stmt,0);
- char *rowData=(char*)::sqlite3_column_text(stmt,1);
- if(rowData==NULL)rowData="NULL";
- */
- }
- //释放statement
- ::sqlite3_finalize(stmt);
- //关闭数据库
- ::sqlite3_close(db);
- ::fclose(fp);
- }
VS2013 Sqlite3 操作指令的更多相关文章
- linux常用操作指令
Linux常用操作指令: 常用指令 ls 显示文件或目录 -l 列出文件详细信息l(list) -a 列出当前目录下所有文件及目录,包括隐藏的a(a ...
- ARM指令集——条件执行、内存操作指令、跳转指令
ARM 汇编指令条件执行 在ARM模式下,任何一条数据处理指令可以选择是否根据操作的结果来更新CPSR寄存器中的ALU状态标志位.在数据处理指令中使用S后缀来实现该功能. 不要在CMP,CMN,TST ...
- 汇编实现: C库常见函数,串操作指令作用
目录 汇编实现: C库常见函数 一丶汇编实现Strncpy拷贝函数 二丶loads实现Strlen操作. 三丶stos的作用 汇编实现: C库常见函数 一丶汇编实现Strncpy拷贝函数 void _ ...
- 深入理解JVM(1)——栈和局部变量操作指令
将常量压入栈的指令 aconst_null 将null对象引用压入栈iconst_m1 将int类型常量-1压入栈iconst_0 将int类型常量0压入栈iconst_1 将int类型常量1压入栈i ...
- 【转】Reflector、reflexil、De4Dot、IL相关操作指令合集
PS:CTRL+F 输入你需要的内容,可以快速查找页面上的内容. 名称 说明 Add 将两个值相加并将结果推送到计算堆栈上. Add.Ovf 将两个整数相加,执行溢出检查,并且将结果推送到计算堆栈上. ...
- 汇编语言--微机CPU的指令系统(五)(字符串操作指令)
(11)字符串操作指令 字符串操作指令的实质是对一片连续存储单元进行处理,这片存储单元是由隐含指针DS:SI或ES:DI来指定的.字符串操作指令可对内存单元按字节.字或双字进行处理,并能根据操作对象的 ...
- Docker下操作指令
Docker下操作指令 以mysql为例 1.搜索镜像: #docker search mysql 2.拉取镜像 #docker pull mysql:5.7 3.加载镜像并绑定端口: #docker ...
- python文件操作指令
原文地址:http://www.cnblogs.com/rollenholt/archive/2012/04/23/2466179.html 常用的文件操作指令: python中对文件.文件夹(文件操 ...
- DOM操作指令整理
DOM操作指令整理: (1) 创建新节点: createDocumentFragment() 创建一个DOM片段 creatElement() 创建一个具体的元素 creatTextNode() 创建 ...
随机推荐
- python——集合
在python中,字典的亲戚就是集合,集合就是无映射关系的字典,花括号并不是字典的特权.如下面程序所示: >>> num = {} >>> type(num) &l ...
- python基础之正则表达式爬虫应用,configparser模块和subprocess模块
正则表达式爬虫应用(校花网) 1 import requests 2 import re 3 import json 4 #定义函数返回网页的字符串信息 5 def getPage_str(url): ...
- [EXCEL]使用技巧随记
1.比对两列中是否有重复项(B列中是否和A列重复) =IF(COUNTIF(A:A,B1)=0,"不重复","重复") Excel中用vlookup函数来对比两 ...
- 2 实现第一个Django网站 博客
-1.理解上下文 render()渲染 request url传来的reuqest x.html 制定返回的模板名称 context 上下文 数据库中 替换数据 0.大框架 1.创建模板 (1 ...
- RandomAecessFile open failed: EISDIR (Is a directory)
今天下午搞断点续传,下载文件的时候,弄了一下,我把下载的文件命名为plug.jar.后来老是报错: open failed: EISDIR (Is a directory) 我烦了,两个小时啊,我操. ...
- android获取未安装APK签名信息及MD5指纹
站在巨人的肩膀上写博客: http://blog.csdn.net/wulianghuan/article/details/18400581 http://www.jb51.net/article/7 ...
- Java 泛型 二
一. 泛型概念的提出(为什么需要泛型)? 首先,我们看下下面这段简短的代码: 1 public class GenericTest { 2 3 public static void main(Stri ...
- Eclipse 工作空间(Workspace)---Eclipse教程第07课
Eclipse 工作空间(Workspace) eclipse 工作空间包含以下资源: 项目 文件 文件夹 项目启动时一般可以设置工作空间,你可以将其设置为默认工作空间,下次启动后无需再配置: 工作空 ...
- [转]多多“亦”善:把大量内容放到一页PPT的5个技巧
技巧一:利用灰色“隐蔽”内容 灰色有个好处:自动成为“备胎”,在“现任”被浏览后才会被注意到.所以使用灰色能够让页面内容看起来没那么多. 技巧二:对齐和亲密 这是排版的两个原则. 对齐是指对页面上的元 ...
- pip 代理设置,坑爹的代理继续
Linux ubuntu 3.2.0-23-generic-pae #36-Ubuntu SMP Tue Apr 10 22:19:09 UTC 2012 i686 i686 i386 GNU/Lin ...