`
chinamming
  • 浏览: 140790 次
  • 性别: Icon_minigender_1
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

一步一步实现C++操作SQLite数据库

 
阅读更多
一步一步实现C++操作SQLite数据库

SQLite,是一款轻型的数据库,是遵守ACID的关联式关系数据库,目前已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了。它能够支持Windows/Linux/Unix等等主流的操作系统,同样的代码可以实现跨平台编译,这个数据库和微软的Access很象,都是小型的数据库管理系统,最大的差别为sqlite不需要office的支持,可以完全开源,是真正意义上的跨平台的数据库

由于工作的需要,这几天对sqlite数据库研究一下,并使用C++对其进行了简单的操作。中间遇到了很多问题,找到了很多资料终于解决了。总结问题,不管提高,所以把遇到的问题和解决办法写出来,希望对大家有用。

1:下载源码并编译

我下的版本为sqlite-amalgamation-3070701.zip,这个包含了主要的源代码。sqlite-dll-win32-x86-3070701.zip这个是Windows下的编译好的DLL文件和def文件,解压缩后包含两个文件,sqlite3.defsqlite3.dll

编译源代码很简单,新建立一个C++空项目,把sqlite-amalgamation-3070701.zip解压缩后的文件拷进去,编译、链接,就行了。

我的目的是把sqlite数据库作为自己项目中的一部分,是作为嵌入的一部分使用的。这个要利用到sqlite3.dll文件。可是源文件只有sqlite3.defsqlite3.dll没有sqlite3.lib文件,怎么用呢?

LIB文件和DLL文件其实是差不多的,只是使用的时间不同。LIB文件使用在编译阶段DLL文件使用在运行阶段。根据def文件可以生成对应的LIB文件。以下是命令行生成LIB文件。

找到VS的安装路径,我的是D:\ProgramFiles\,用命令行进入以下路径。

D:\ProgramFiles\MicrosoftVisualStudio9.0\VC\bin>lib/def:sqlite3.def/machine:ix86

问题一:mspdb80.dll无法找到

原因是当前路径下没有“msobj80.dll,mspdb80.dll,mspdbcore.dll,mspdbsrv.exe”这四个文件。

解决办法:Common7\IDE\下复制这四个文件到VC\Bin\下即可解决。

对应生成lib文件需要注意的是把sqlite3.def拷到上述路径下,使用命令行生成后会产生sqlite3.lib文件,这个就是在程序中编译时需要的文件。显示的结果为:

Microsoft(R)LibraryManagerVersion9.00.21022.08

Copyright(C)MicrosoftCorporation.Allrightsreserved.

正在创建库sqlite3.lib和对象sqlite3.exp

2:在C++中操作SQLite数据库

问题二:没有找到sqlite3.dll,因此这个应用程序未能启动

我在我把sqlite3.dllsqlite3.hsqlite3.lib拷到同一个文件夹里,编译时已知出现这个问题。

原来是程序执行时需要的DLL按照当前工作路径、系统目录的顺序搜索DLL文件。我的DLL文件没有和可执行文件在同一个路径下,肯定要出错了。明白这些,把sqlite3.dll拷到Debug文件夹下,问题解决了。

3:演示代码

主要的源代码来自网上,这个是我修改过的。

  1. #include<iostream>
  2. usingnamespacestd;
  3. #include"./sqlite/sqlite3.h"
  4. #pragmacomment(lib,"./sqlite/sqlite3.lib")
  5. staticint_callback_exec(void*notused,intargc,char**argv,char**aszColName)
  6. {
  7. inti;
  8. for(i=0;i<argc;i++)
  9. {
  10. printf("%s=%s\n",aszColName[i],argv[i]==0?"NUL":argv[i]);
  11. }
  12. return0;
  13. }
  14. intmain(intargc,char*argv[])
  15. {
  16. constchar*file="test.db";
  17. constchar*sSQL="select*fromstu;";
  18. char*pErrMsg=0;
  19. intret=0;
  20. sqlite3*db=0;
  21. ret=sqlite3_open("./test.db",&db);
  22. if(ret!=SQLITE_OK)
  23. {
  24. fprintf(stderr,"Couldnotopendatabase:%s",sqlite3_errmsg(db));
  25. exit(1);
  26. }
  27. printf("Successfullyconnectedtodatabase\n");
  28. sqlite3_exec(db,sSQL,_callback_exec,0,&pErrMsg);
  29. if(ret!=SQLITE_OK)
  30. {
  31. fprintf(stderr,"SQLerror:%s\n",pErrMsg);
  32. sqlite3_free(pErrMsg);
  33. }
  34. sqlite3_close(db);
  35. db=0;
  36. return0;
  37. }

4SQLite使用小问题说明

我在命令行操作SQLite数据库时,进入后一直不能生成一个数据库,并且生成表的命令也不成功。

后来终于明白了,SQLite命令行的形式为:sqlite.exedbfile,后面的即为数据库名,如果不存在,在操作后会自动生成一个数据库名。

SQLiteSQL命令都是以“;”为结束符,开始一直执行不成功,原来是没有加入“;”语句结束符号。

终于完成了一个简单的操作SQLite的程序。
分享到:
评论

相关推荐

    C++操作sqlite数据库

    codeblock下操作sqlite数据库简明教程及示例代码

    Sqlite3 C++ 简单单例数据库操作类封装

    Sqlite3 C++ 简单单例数据库操作类封装,支持数据的简单操作,可用,尚不完善

    c++连接sqlite数据库

    c++连接sqlite数据库的实例 c++连接sqlite数据库的实例

    C/C++连接SQLite数据库及基本操作

    用VC++6.0开发的基于对话框的应用程序,可以编译运行。目录下有一个名为student.db的文件,...这个代码说明了怎么用C/C++连接SQLite数据库文件及进行基本的操作,比如插入新的数据,查询数据。对学习SQLite数据库有帮助

    sqlite数据库c++类封装,及源码实例,boost多线程

    sqlite数据库,用c++封装类,以及源码实现的对sqlite数据库封装类的操作。同时有boost多线程对sqlite数据库进行操作。 真是学习居家的好例子。。。。

    sqlite数据库操作

    Android 提供了一个名为 SQLiteDatabase 的类,该类封装了一些操作数据库的 API,使用该类可以完成对数据进行添加(Create)、查询(Retrieve)、更新(Update)和删除(Delete)操作(这些操作简称为 CRUD) 。

    JavaScript操作SQLite数据库Demo

    JavaScript操作SQLite数据库Demo,不需要安装软件,可直接操作SQLite数据库。(推荐下载SQLiteStudio查看生成的数据是否正确)。

    C++ 读写Excel以及操作SQLite

    该文件中包含有: 1、NPOI_EXCEL工程: 该工程文件中包含有C#工程对NPOI.dll的的读写进行封装成类库的操作,主要是使用... 该工程是C++操作数据库的简单封装,主要是对数据库的基本操作,涉及有SQLite和SQL Sever数据库

    BCB6.0操作SQLite数据库

    BCB6.0 使用 sqlite 数据库简单方法, 工程--添加到工程---选择 .c类型 添加 sqlite3.c再引入头文件 #include "sqlite3.h"。例程可以帮助新学SQLite入门。

    使用C#开发的Sqlite数据库创建、操作的源码项目工程

    这是一个使用C#开发的Sqlite数据库创建、操作的源码工程,关于Sqlite的所有操作已经单独创建了专门的跨平台【.NETCore3.1】类库包含相应的帮助类,可以直接生成后拿到任何项目中直接使用,高效简单,省去了从头开发...

    C++插入SQLite数据库的BLOB字段

    使用环境是VS2010,往SQLite数据库的BLOB字段里插入jpg,主要修改路径和文件名也可以换成其他文件。工程里也自带SQLite的编译文件,如果需要的也可以下载。

    VC 操作sqlite数据库

    C++ sqlite c++操作sqlite数据库,查询及插入demo,rum

    C#操作SQLite数据库之读写数据库的方法

    本文实例讲述了C#操作SQLite数据库之读写数据库的方法。分享给大家供大家参考,具体如下: 这里演示读写数据库并在窗体(Form)中显示其数据,其方式为: 读: Database(SQLite) -&gt; DataAdapter -&gt; DataSet -&gt; ...

    SQLite数据库设计与实现 英文版

    介绍了数据库的概念,数据库设计与实现的相关知识,系统讲解了sqllite主要组件。

    sqlite数据库 压缩 释放数据冗余空间

    sqlite数据库文件经多次添加删除操作后 文件占用磁盘空间过大 c++压缩文件代码 sqlite数据库文件经多次添加删除操作后 文件占用磁盘空间过大 c++压缩文件代码 测试调用TestFunction.h文件 bool commit_vacuum...

    数据库sqlite 小型数据库

    数据库sqlite 小型数据库数据库sqlite

    SQLite数据库文件自收缩_sqlite3_

    通过相关配置,删除数据后,实现SQLite3设置数据库文件自动收缩

    C++连接sqlite数据库

    这是一个用于C++连接sqlite数据库所需的文件,直接放在工程里面就行。然后再你的工程里包括头文件和库文件即可

    labview操作sqlite读、写数据库

    在官方提供的sqlite3.dll上对库节点进行了封装,实现labview操作sqlite读、写数据库,在14版本测试验证通过。

    用VB.net操作SQLite数据库的完整工程代码

    用VB.net操作SQLite数据库 还包括详细的图文教程的博客链接 如有需要可以下载 物超所值

Global site tag (gtag.js) - Google Analytics