一.如何备份数据库
先打开数据库test.db
E:\sqlite\tool\sqlite-3_6_22>sqlite3D:\Test\deBUG\test.db
sqlite> .backup D:\\Test\\deBUG\\test.bak
注意:一定要用\\双斜杠
二.如何恢复数据库先打开数据库test.db
E:\sqlite\tool\sqlite-3_6_22>sqlite3D:\Test\deBUG\test.db
sqlite> .restore D:\\Test\\deBUG\\test.bak
注意:一定要用\\双斜杠
三.先判断表如果不存在,则再创建表sql可以如下写,供参考:
create table if not exists student(ID integer primary key autoincrement,\
age smallint,anchor smallint);
四.如何查询sqlite3小工具或者sqlite3.dll动态链接库的版本执行select sqlite_version();命令即可
五.sqlite3的最新版本是(截止日期2010年2月22日)3.6.22
六.针对sqlite3,两大优秀C++封装库1.Cppsqlite3
http://www.codeproject.com/KB/database/CppSQLite.aspx
2.wxsqlite3
http://sourceforge.net/projects/wxcode/files/Components/wxSQLite3/wxsqlite3-1.9.8.zip/download
七.如何在windows下编译sqlite31.先从官网获取sqlite-amalgamation-3_6_22.zip;
2.接着从官网获取sqlitedll-3_6_22.zip
下载编译好的DLL,这里有我们需要的sqlite3.def该文件
3.打开VC新建一个“Win32 Dynamic-link library”工程,命名为:sqlite3;
4.在接下来的对话框中选择"An empty DLL project",点FINISH->OK;
5.将sqlite-amalgamation-3_6_22文件夹下的sqlite3.h以及sqlite3.c两个文件复制到工程文件夹下;
将sqlitedll-3_6_22文件夹下的sqlite3.def该文件复制到工程文件夹下;
6.在工程的Source files中添加sqlite3.c文件;
7.在工程的Include files中添加sqlite3.h文件;
8.在工程的Resource files中添加sqlite3.def文件;
9.针对如下问题:
sqlite3.def : error LNK2001: unresolved external symbol sqlite3_column_database_name
sqlite3.def : error LNK2001: unresolved external symbol sqlite3_column_database_name16
sqlite3.def : error LNK2001: unresolved external symbol sqlite3_column_origin_name
sqlite3.def : error LNK2001: unresolved external symbol sqlite3_column_origin_name16
sqlite3.def : error LNK2001: unresolved external symbol sqlite3_column_table_name
sqlite3.def : error LNK2001: unresolved external symbol sqlite3_column_table_name16
sqlite3.def : error LNK2001: unresolved external symbol sqlite3_table_column_Metadata
DeBUG/sqlite3.lib : Fatal error LNK1120: 7 unresolved externals
在菜单【Project】-【Settings…】-【C/C++】标签下的category【General】下
Preprocessor deFinitions下:
新增2个编译选项,分别是:
THREADSAFE
sqlITE_ENABLE_ColUMN_MetaDATA
10.往工程中添加sqlite3.def文件就是为生成sqlite3.lib文件;
sqlite3.lib是与sqlite3.dll动态链接库文件一起提供给软件开发者的;
八.如何解决windows下的编译警告e:\sqlite\code\sqlite3\sqlite3.c(15385) : warning C4047: 'function' : 'voID ** ' differs in levels of indirection from 'long *'
e:\sqlite\code\sqlite3\sqlite3.c(15385) : warning C4022: 'InterlockedCompareExchange' : pointer mismatch for actual parameter 1
e:\sqlite\code\sqlite3\sqlite3.c(15385) : warning C4022: 'InterlockedCompareExchange' : pointer mismatch for actual parameter 2
e:\sqlite\code\sqlite3\sqlite3.c(15403) : warning C4047: 'function' : 'voID ** ' differs in levels of indirection from 'long *'
e:\sqlite\code\sqlite3\sqlite3.c(15403) : warning C4022: 'InterlockedCompareExchange' : pointer mismatch for actual parameter 1
e:\sqlite\code\sqlite3\sqlite3.c(15403) : warning C4022: 'InterlockedCompareExchange' : pointer mismatch for actual parameter 3
e:\sqlite\code\sqlite3\sqlite3.c(15403) : warning C4047: '==' : 'voID *' differs in levels of indirection from 'const int '
e:\sqlite\code\sqlite3\sqlite3.c(65536) : warning C4049: compiler limit : terminating line number emission
warning C4761: integral size mismatch in argument; conversion supplIEd
warning C4761: integral size mismatch in argument; conversion supplIEd
warning C4761: integral size mismatch in argument; conversion supplIEd
转了几个sqlite的文章,慢慢阅读一下~
总结以上是内存溢出为你收集整理的SQLite学习笔记(三)全部内容,希望文章能够帮你解决SQLite学习笔记(三)所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)