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

2014-11-24 18:19:19 · 作者: · 浏览: 0

由于工作的需要,这几天对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:\Program Files\,用命令行进入以下路径。


D:\Program Files\Microsoft Visual Studio 9.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) Library Manager Version 9.00.21022.08


Copyright (C) Microsoft Corporation. All rights reserved.


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


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


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


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


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


3:演示代码


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