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:\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:演示代码

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

[cpp]  view plain copy
  1. #include <iostream>   
  2. using namespace std;  
  3. #include "./sqlite/sqlite3.h"  
  4. #pragma comment(lib, "./sqlite/sqlite3.lib")  
  5. static int _callback_exec(void * notused,int argc, char ** argv, char ** aszColName)  
  6. {  
  7.     int i;  
  8.     for ( i=0; i<argc; i++ )  
  9.     {  
  10.         printf( "%s = %s\n", aszColName[i], argv[i] == 0 ? "NUL" : argv[i] );  
  11.     }  
  12.     return 0;  
  13. }  
  14. int main(int argc,char * argv[])  
  15. {  
  16.     const char * file ="test.db";  
  17.     const char * sSQL = "select * from stu;";  
  18.     char * pErrMsg = 0;  
  19.     int ret = 0;  
  20.     sqlite3 * db = 0;  
  21.     ret = sqlite3_open("./test.db", &db);  
  22.     if ( ret != SQLITE_OK )  
  23.     {  
  24.         fprintf(stderr, "Could not open database: %s", sqlite3_errmsg(db));  
  25.         exit(1);  
  26.     }  
  27.     printf("Successfully connected to database\n");  
  28.     sqlite3_exec( db, sSQL, _callback_exec, 0, &pErrMsg );  
  29.     if ( ret != SQLITE_OK )  
  30.     {  
  31.         fprintf(stderr, "SQL error: %s\n", pErrMsg);  
  32.         sqlite3_free(pErrMsg);  
  33.     }  
  34.   
  35.     sqlite3_close(db);  
  36.     db = 0;  
  37.   
  38.     return 0;  
  39. }  
[cpp]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. #include <iostream>  
  2. using namespace std;  
  3. #include "./sqlite/sqlite3.h"  
  4. #pragma comment(lib, "./sqlite/sqlite3.lib")  
  5. static int _callback_exec(void * notused,int argc, char ** argv, char ** aszColName)  
  6. {  
  7.     int i;  
  8.     for ( i=0; i<argc; i++ )  
  9.     {  
  10.         printf( "%s = %s\n", aszColName[i], argv[i] == 0 ? "NUL" : argv[i] );  
  11.     }  
  12.     return 0;  
  13. }  
  14. int main(int argc,char * argv[])  
  15. {  
  16.     const char * file ="test.db";  
  17.     const char * sSQL = "select * from stu;";  
  18.     char * pErrMsg = 0;  
  19.     int ret = 0;  
  20.     sqlite3 * db = 0;  
  21.     ret = sqlite3_open("./test.db", &db);  
  22.     if ( ret != SQLITE_OK )  
  23.     {  
  24.         fprintf(stderr, "Could not open database: %s", sqlite3_errmsg(db));  
  25.         exit(1);  
  26.     }  
  27.     printf("Successfully connected to database\n");  
  28.     sqlite3_exec( db, sSQL, _callback_exec, 0, &pErrMsg );  
  29.     if ( ret != SQLITE_OK )  
  30.     {  
  31.         fprintf(stderr, "SQL error: %s\n", pErrMsg);  
  32.         sqlite3_free(pErrMsg);  
  33.     }  
  34.   
  35.     sqlite3_close(db);  
  36.     db = 0;  
  37.   
  38.     return 0;  
  39. }  

4SQLite使用小问题说明

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

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

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

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

更多推荐