设为首页 收藏本站
查看: 920|回复: 0

[经验分享] 一步一步实现C++操作SQLite数据库

[复制链接]

尚未签到

发表于 2016-11-30 10:39:17 | 显示全部楼层 |阅读模式
一步一步实现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:演示代码
  主要的源代码来自网上,这个是我修改过的。

[cpp]
view plaincopyprint?





  • #include<iostream>

  • usingnamespacestd;

  • #include"./sqlite/sqlite3.h"

  • #pragmacomment(lib,"./sqlite/sqlite3.lib")

  • staticint_callback_exec(void*notused,intargc,char**argv,char**aszColName)
  • {

  • inti;

  • for(i=0;i<argc;i++)
  • {

  • printf("%s=%s\n",aszColName,argv==0?"NUL":argv);
  • }

  • return0;
  • }

  • intmain(intargc,char*argv[])
  • {

  • constchar*file="test.db";

  • constchar*sSQL="select*fromstu;";

  • char*pErrMsg=0;

  • intret=0;
  • sqlite3*db=0;

  • ret=sqlite3_open("./test.db",&db);

  • if(ret!=SQLITE_OK)
  • {

  • fprintf(stderr,"Couldnotopendatabase:%s",sqlite3_errmsg(db));
  • exit(1);
  • }

  • printf("Successfullyconnectedtodatabase\n");
  • sqlite3_exec(db,sSQL,_callback_exec,0,&pErrMsg);

  • if(ret!=SQLITE_OK)
  • {

  • fprintf(stderr,"SQLerror:%s\n",pErrMsg);
  • sqlite3_free(pErrMsg);
  • }

  • sqlite3_close(db);
  • db=0;


  • return0;
  • }



#include <iostream>
using namespace std;
#include "./sqlite/sqlite3.h"
#pragma comment(lib, "./sqlite/sqlite3.lib")
static int _callback_exec(void * notused,int argc, char ** argv, char ** aszColName)
{
int i;
for ( i=0; i<argc; i++ )
{
printf( "%s = %s\n", aszColName, argv == 0 ? "NUL" : argv );
}
return 0;
}
int main(int argc,char * argv[])
{
const char * file ="test.db";
const char * sSQL = "select * from stu;";
char * pErrMsg = 0;
int ret = 0;
sqlite3 * db = 0;
ret = sqlite3_open("./test.db", &db);
if ( ret != SQLITE_OK )
{
fprintf(stderr, "Could not open database: %s", sqlite3_errmsg(db));
exit(1);
}
printf("Successfully connected to database\n");
sqlite3_exec( db, sSQL, _callback_exec, 0, &pErrMsg );
if ( ret != SQLITE_OK )
{
fprintf(stderr, "SQL error: %s\n", pErrMsg);
sqlite3_free(pErrMsg);
}
sqlite3_close(db);
db = 0;
return 0;
}
  4SQLite使用小问题说明
  我在命令行操作SQLite数据库时,进入后一直不能生成一个数据库,并且生成表的命令也不成功。
  后来终于明白了,SQLite命令行的形式为:sqlite.exedbfile,后面的即为数据库名,如果不存在,在操作后会自动生成一个数据库名。
  SQLiteSQL命令都是以“;”为结束符,开始一直执行不成功,原来是没有加入“;”语句结束符号。



终于完成了一个简单的操作SQLite的程序。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-307625-1-1.html 上篇帖子: 练手写了个SQLite解析器 下篇帖子: 如何在QML使用Sqlite数据库
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表