1. extern "C"{
  2. #include "sqlite3.h"
  3. };
  4. #pragma comment(lib,"sqlite.lib")
  5. /*
  6. 为什么要 extern “C” ?这是C++的基础。要在 C++里使用一段 C 的代码,必须要用 extern “C” 括起来。C++跟 C虽然语法上有重叠,但是它们是两个不同的东西,内存里的布局是完全不同的,在C++编译器里不用extern “C”括起C代码,会导致编译器不知道该如何为 C 代码描述内存布局。可能在 sqlite3.c 里人家已经把整段代码都 extern “C” 括起来了,但是你遇到一个.c 文件就自觉的再括一次,也没什么不好。
  7. */
  8. //-----------------------------------------------------OK,尽情的爽吧---------------------------------------------------//
  9. 下载是我简单作用sqlite3的代码,不好看,请包涵!
  10. 详细教程在这:http://download.csdn.net/detail/q775968375/5970059
  11. void CMySqliteDlg::OnBnClickedOk()
  12. {
  13. // TODO: 在此添加控件通知处理程序代码
  14. //CDialogEx::OnOK();
  15. CTime m_time;
  16. m_time=CTime::GetCurrentTime();//获取当前时间日期
  17. FILE *fp=fopen("debug.txt","a+");
  18. fprintf(fp,"\n------------------------%s------------------------\n"
  19. ,m_time.Format(_T("%Y-%m-%d %H:%M:%S %A")));
  20. ::sqlite3 *db=NULL;
  21. ::sqlite3_stmt *stmt;
  22. char *sql=NULL,*error=NULL;
  23. const char *tail=NULL;
  24. int res;
  25. res=::sqlite3_open("MySqlite.db",&db);//打开数据库(不存在创建)
  26. if(res!=SQLITE_OK){
  27. ::sqlite3_close(db);
  28. fprintf(fp,"open database is failure:%s\n",::sqlite3_errmsg(db));
  29. return;
  30. }else fprintf(fp,"open database is success!\n");
  31. //create table
  32. sql="create table if not exists MyTable(Row integer primary key autoincrement,Content text)";
  33. res=::sqlite3_exec(db,sql,NULL,NULL,&error);
  34. if(res!=SQLITE_OK){
  35. ::sqlite3_close(db);
  36. fprintf(fp,"error create table:%s %s\n",error,::sqlite3_errmsg(db));
  37. return;
  38. }else fprintf(fp,"table is created\n");
  39. //insert
  40. sql="insert or replace into MyTable(Row,Content) values(?,?)";
  41. //sqlite3_prepare_v2的作用是将UTF-8格式的SQL语句转换为编译后的语句,并返回指向该语句的指针
  42. res=::sqlite3_prepare_v2(db,sql,-1,&stmt,&tail);
  43. if(res!=SQLITE_OK){
  44. ::sqlite3_close(db);
  45. fprintf(fp,"insert is failure:%s %s\n",tail,::sqlite3_errmsg(db));
  46. return;
  47. }
  48. for(int i=0;i<3;i++){
  49. //::sqlite3_bind_int(stmt,1,0);//1:id  2:data
  50. ::sqlite3_bind_text(stmt,2,"数据库数据",-1,NULL);
  51. if(::sqlite3_step(stmt)!=SQLITE_DONE){
  52. fprintf(fp,"error update table:%s\n",::sqlite3_errmsg(db));
  53. }
  54. ::sqlite3_reset(stmt); //重新初始化该sqlite3_stmt对象绑定的变量。
  55. }
  56. ::sqlite3_finalize(stmt);
  57. //delete
  58. sql="delete from MyTable where Row=2";
  59. //res=::sqlite3_prepare_v2(db,sql,-1,&stmt,&tail);
  60. res=::sqlite3_exec(db,sql,NULL,NULL,&error);
  61. if(res!=SQLITE_OK){
  62. ::sqlite3_close(db);
  63. fprintf(fp,"delete error:%s %s\n",error,::sqlite3_errmsg(db));
  64. return;
  65. }else fprintf(fp,"delete is success\n");
  66. ::sqlite3_finalize(stmt);
  67. //update
  68. sql="update MyTable set Content='修改后的数据' where Row=3";
  69. res=::sqlite3_exec(db,sql,NULL,NULL,&error);
  70. if(res!=SQLITE_OK){
  71. ::sqlite3_close(db);
  72. fprintf(fp,"update error:%s %s\n",error,::sqlite3_errmsg(db));
  73. return;
  74. }else fprintf(fp,"update is success\n");
  75. ::sqlite3_finalize(stmt);
  76. //query
  77. sql="select Row,Content from MyTable order by Row";
  78. res=::sqlite3_prepare_v2(db,sql,-1,&stmt,&tail);
  79. if(res!=SQLITE_OK){
  80. ::sqlite3_close(db);
  81. fprintf(fp,"query is failure:%s %s\n",tail,::sqlite3_errmsg(db));
  82. return;
  83. }
  84. while(::sqlite3_step(stmt)==SQLITE_ROW){
  85. static int cnt=::sqlite3_column_count(stmt);
  86. for(int i=0;i<cnt;i++){
  87. fprintf(fp,"Data:%s\n",::sqlite3_column_text(stmt,i));
  88. }
  89. /*
  90. int row=::sqlite3_column_int(stmt,0);
  91. char *rowData=(char*)::sqlite3_column_text(stmt,1);
  92. if(rowData==NULL)rowData="NULL";
  93. */
  94. }
  95. //释放statement
  96. ::sqlite3_finalize(stmt);
  97. //关闭数据库
  98. ::sqlite3_close(db);
  99. ::fclose(fp);
  100. }

VS2013 Sqlite3 操作指令的更多相关文章

  1. linux常用操作指令

    Linux常用操作指令: 常用指令 ls        显示文件或目录 -l           列出文件详细信息l(list) -a          列出当前目录下所有文件及目录,包括隐藏的a(a ...

  2. ARM指令集——条件执行、内存操作指令、跳转指令

    ARM 汇编指令条件执行 在ARM模式下,任何一条数据处理指令可以选择是否根据操作的结果来更新CPSR寄存器中的ALU状态标志位.在数据处理指令中使用S后缀来实现该功能. 不要在CMP,CMN,TST ...

  3. 汇编实现: C库常见函数,串操作指令作用

    目录 汇编实现: C库常见函数 一丶汇编实现Strncpy拷贝函数 二丶loads实现Strlen操作. 三丶stos的作用 汇编实现: C库常见函数 一丶汇编实现Strncpy拷贝函数 void _ ...

  4. 深入理解JVM(1)——栈和局部变量操作指令

    将常量压入栈的指令 aconst_null 将null对象引用压入栈iconst_m1 将int类型常量-1压入栈iconst_0 将int类型常量0压入栈iconst_1 将int类型常量1压入栈i ...

  5. 【转】Reflector、reflexil、De4Dot、IL相关操作指令合集

    PS:CTRL+F 输入你需要的内容,可以快速查找页面上的内容. 名称 说明 Add 将两个值相加并将结果推送到计算堆栈上. Add.Ovf 将两个整数相加,执行溢出检查,并且将结果推送到计算堆栈上. ...

  6. 汇编语言--微机CPU的指令系统(五)(字符串操作指令)

    (11)字符串操作指令 字符串操作指令的实质是对一片连续存储单元进行处理,这片存储单元是由隐含指针DS:SI或ES:DI来指定的.字符串操作指令可对内存单元按字节.字或双字进行处理,并能根据操作对象的 ...

  7. Docker下操作指令

    Docker下操作指令 以mysql为例 1.搜索镜像: #docker search mysql 2.拉取镜像 #docker pull mysql:5.7 3.加载镜像并绑定端口: #docker ...

  8. python文件操作指令

    原文地址:http://www.cnblogs.com/rollenholt/archive/2012/04/23/2466179.html 常用的文件操作指令: python中对文件.文件夹(文件操 ...

  9. DOM操作指令整理

    DOM操作指令整理: (1) 创建新节点: createDocumentFragment() 创建一个DOM片段 creatElement() 创建一个具体的元素 creatTextNode() 创建 ...

随机推荐

  1. 浅谈XX系统跨平台迁移(测试环境)

    一 概述 XX系统目前运行在XX-A的云平台上,计划将其迁移至XX-B的云平台. XX系统是java开发,中间组件涉及nginx+keepalived实现各个业务系统之间的高可用,kafka,zook ...

  2. 笔记-scrapy-cookie

    笔记-scrapy-cookie传递 1.      scrapy cookie传递 1.1.    开始 与cookie相关的设置参数有两个: COOKIES_ENABLED 决定是否使用cooki ...

  3. scrapy进行分布式爬虫

    今天,参照崔庆才老师的爬虫实战课程,实践了一下分布式爬虫,并没有之前想象的那么神秘,其实非常的简单,相信你看过这篇文章后,不出一小时,便可以动手完成一个分布式爬虫! 1.分布式爬虫原理 首先我们来看一 ...

  4. zookeeper: web ui工具的安装

    zookeeper官方没有提供web用户界面,这使很多人在使用zookeeper(动物管理员)同时,并不是很容易的理解zookeeper的数据结构,还好淘宝有位大神用Nodejs写了一个web的ui工 ...

  5. Android面试收集录6 事件分发机制

    转自:秋招面试宝典. 一. 基础认知 1.1 事件分发的对象是谁? 答:事件 当用户触摸屏幕时(View或ViewGroup派生的控件),将产生点击事件(Touch事件). Touch事件相关细节(发 ...

  6. hihocoder #1394 : 网络流四·最小路径覆盖(最小路径覆盖)

    #1394 : 网络流四·最小路径覆盖 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 国庆期间正是旅游和游玩的高峰期. 小Hi和小Ho的学习小组为了研究课题,决定趁此机 ...

  7. Windows系统安装测试redis

    因本人电脑是windows系统,从https://github.com/ServiceStack/redis-windows下载了兼容windows系统的redis 下载后直接解压到D:\redis目 ...

  8. React + webpack 快速搭建开发环境

    因网上大多React + webpack快速搭建的运行不起来,便自行写了一个.在搭建开发环境的前需安装nodejs,npm. 新建一个工作目录,比如叫reactdome,在reactdome目录中运行 ...

  9. CSS简易学习笔记

    学习地址:http://www.w3school.com.cn/css/index.asp cnblog不能把格式复制上来,有格式文字版:https://github.com/songzhenhua/ ...

  10. 【Python】python内置函数、列表生成式、生成器

    一.内置函数 1 print(all([1,2,3,4]))#判断可迭代的对象里面的值是否都为真 2 print(any([0,1,2,3,4]))#判断可迭代的对象里面的值是否有一个为真 3 pri ...