SQLite学习笔记(三)

转载 2012年03月24日 22:57:32

http://www.cnblogs.com/hicjiajia/archive/2011/01/25/1944583.html


一.如何备份数据库

先打开数据库test.db

E:\sqlite\tool\sqlite-3_6_22>sqlite3  D:\Test\debug\test.db

sqlite> .backup D:\\Test\\debug\\test.bak

注意:一定要用\\双斜杠 

二.如何恢复数据库

先打开数据库test.db

E:\sqlite\tool\sqlite-3_6_22>sqlite3  D:\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下编译SQLite3

1.先从官网获取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的文章,慢慢阅读一下~

相关文章推荐

xamarin学习笔记A10(安卓SQLite)

  • 2017-08-09 22:35
  • 84.89MB
  • 下载

SQLite使用学习笔记

  • 2011-09-19 11:17
  • 100KB
  • 下载

SQLite学习笔记三:Where, AND/OR, Update, Delete

SQLite Where语句 SQLite的 WHERE 子句用于指定从一个表或多个表中获取数据的条件。

SQLite学习笔记(三)

http://www.cnblogs.com/hicjiajia/archive/2011/01/25/1944583.html 一.如何备份数据库 先打开数据库test.db E:...

SQL学习笔记之数据库专题(三):Android下Sqlite数据库ORM框架之GreenDao详解

在大型项目中,android的数据库操作不可能再像第二篇文章那样,用最基础的API去实现各方面的操作,那样效率会十分的底下。那么,在android开发中,提拱了androrm,Ormlite,gree...

SQLite学习笔记之三

2010年SQLite学习笔记之三一.如何备份数据库先打开数据库test.dbE:/sqlite/tool/sqlite-3_6_22>sqlite3  D:/Test/debug/test.dbsq...

ioS学习笔记—— 数据持久化(Sqlite)

1、初始化路径、定义sql

sqlite学习笔记2

内连接 - INNER JOIN内连接(INNER JOIN)根据连接谓词结合两个表(table1 和 table2)的列值来创建一个新的结果表。 查询会把 table1 中的每一行与 table2 ...

SQLite学习笔记(8)

线程:           SQLite的很多版本支持多线程。           共享缓存模型:  &...

Android学习笔记——数据库SQLite

1、什么是SQLight以及SQLight的特点这个不讲2、SQLight的数据类型 类型 说明 NULL 类型为空 VARCHAR(n) 长度不固定,但有最大限制(n)的字串,...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)