Sqlite和SQLCE在Windows Mobile 6上的性能对比
最近公司需要将桌面系统部署到PDA上面去,选择了WM6作为部署平台。在选择数据库方面出现了一点顾虑,因为对于PDA而言,性能是首要考虑的因素。
在开源的数据库Sqlite和SQLCE之间徘徊,所以针对这个情况,对Sqlite和SQLCE在WM6上面做了性能测试。我也将自己在做测试过程中碰到的问题在这里罗列一下,以便让那些在网上查了很久都找不到答案的朋友少走一些弯路。
从两个方面来分析:第一,碰到的问题以及解决方案,第二,测试性能的结果和结论。
第一:首先在部署的时候需要将数据库拷贝到PDA上或者WM上面,拷贝的路径是在程序中写好的路径。测试时,我的路径是"Program Files"smartdevicetest下面。
开始部署时,因为我先测试SQLCE的,出现 “无法找到 PInvoke DLL“sqlceme35.dll” ”的错误,原因是因为在VS自动部署的时候没有将sqlceme35.dll部署到模拟器上面去,导致编译通过,但是运行出错。
在网上找了些解决方案,很多不能用,以下解决方案能行:http://blog.csdn.net/flyjimi/archive/2008/12/11/3500606.aspx 原文地址是:http://blogs.msdn.com/sqlservercompact/archive/2007/10/26/can-t-find-p-invoke-dll-sqlcemenn-dll.aspx 但是在解决方案中,没有写明白具体的操作方法,具体是哪三个CAB文件。然后我就到以下目录下
在这个目录下有很多个CAB,因为我用的是WM5的,所以关于WM5的我都拷贝到模拟器上去, 将选中的文件拷贝到WM5上面,然后到WM上面执行一下,在执行这些文件的时候会出现“已经安装了之前的版本,需要重新安装的点击确定”。点击确定就好了。我的安装顺序是:从下往上依次安装。重新编译,部署,运行,SQLCE通过。
轮到SQLite了,还是按照原来一样将数据库拷贝的目录下面,这里数据库支持的类型暂时我知道是有“.DB”,“.DB3”.后来通过用UltraEdit打开SQLite的数据库发现里面有SQLite3的关键字,所以只要有这个关键字,后缀名不管用什么都是支持的。没有后缀名也是可以的。
还是按原来的一样。部署运行,出现了“无法找到 PInvoke DLL 'SQLite.Interop.064.DLL'”原因当然也是VS部署的时候不会将这个部署上去。郁闷,没有先例的东西就是问题多。没办法,只有尝试。找到SQLite.net的安装目录下。
相关文档:
自几十年前出现的商业应用程序以来,数据库就成为软件应用程序的主要组成部分。正与数据库管理系统非常关键一样,它们也变得非常庞大,并占用了相当多的系
统资源,增加了管理的复杂性。随着软件应用程序逐渐模块模块化,一种新型数据库会比大型复杂的传统数据库管理系统更适应。嵌入式数据库直接在应用程序进程
中 ......
从网上找的例子,创建了一个数据库,追加了几条记录后,然后关闭数据库,然后准备向PDA下载数据库,发现文件竟然被占用了,已经关闭了数据库连接也无效,后来从网上看到需要清除连接池
using (SQLiteConnection cn = new SQLiteConnection("Data Source=" + strTempPath + "\\Smoke.db3;Pooling=true;FailIfMissing=false ......
sqlite官方站
http://www.sqlite.org/
SQL Syntax
http://www.sqlite.org/lang.html
sqlite中文站
http://www.sqlite.com.cn/
http://www.sqlitechina.org/
建立数据库档案
用sqlite3建立数据库的方法很简单,只要在shell下键入(以下$符号为shell提示号,请勿键入):
$ sqlite3 foo.db
如果目录下没有fo ......
前一阵字做项目(嵌入式linux),由于要保存大量的数据,而且最长要保存30天的时间。本来打算保存到文件中,每次启动应用程序的时候重新解析一遍,可是当数据量很大的时候,就出现效率的问题了。所以最后还是放弃了使用文件的打算,决定使用数据库存取数据。
linux下的数据库也很多,有开源的,也有收费的。对于我们来说,肯 ......
.nullvalue STRING 用STRING代替null值显示,不难理解,就不再累述了。
.output FILENAME 设置把查询输出到文件,后面的输出结果都保存到文件中,如:
sqlite> .mode list
sqlite> .output websites.txt
sqlite> select * from websites;
sqlite>
可以在F盘下发现建立了websites.txt文件,其内容如下:
......