在.NET Campact Framework常用SQL CE数据库进行数据存储,SQL CE是一个扩 展名为*.sdf的文件数据库,曾经命名为SQL Server for Windows CE和SQL Server Mobile Edition,最新版本命名为SQL Server Compact Edition,在文章 中统一叫SQL CE。本文主要讲述SQL CE 3.0和SQL CE 3.5的兼容性问题。
.NET Campact Framework下开发SQL CE统一使用 System.Data.SqlServerCe.dll,该dll封装的命名空间和类是一致的,所以程序 代码是统一的。但是由于*.sdf数据文件格式不一样,MS提供不同版本 System.Data.SqlServerCe.dll,其相关组件存放的位置也不一样。
在vs2005下开发默认使用CF.net的版本为2.0,同时默认使用的SQL CE版本是 3.0。一般在以下目录 C:\Program Files\Microsoft Visual Studio 8 \SmartDevices\SDK\SQL Server\Mobile\v3.0或者C:\Program Files\Microsoft SQL Server 2005 Mobile Edition\Device\Mobile\v3.0。
在vs2008下开发默认使用CF.net的版本为3.5,但是可以选择2.0,同时默认使 用的SQL CE版本是3.5。一般存放在C:\Program Files\Microsoft SQL Server Compact Edition\v3.5\Devices\。
sdf数据文件和System.Data.SqlServerCe.dll是一对一绑定,3.5的sdf数据文 件只能用3.5的SqlServerCe.dll,3.0的sdf数据文件只能用3.0的 SqlServerCe.dll的,彼此互不兼容。
如果使用3.0的SqlServerCe.dll访问3.5的sdf数据文件会有以下异常
System.Data.SqlServerCe.SqlCeException : You are trying to access an older version of a SQL Server
Mobile database. If this is a SQL Server CE 1.0 or 2.0 database, run upgrade.exe.
If this is a SQL Server Mobile 3.0 database, run Compact / Repair.
[ Db version = 3505053,Requested version = 3004180,File name = DB\db.sdf ]
at System.Data.SqlServerCe.SqlCeConnection.ProcessResults()
at System.Data.SqlServerCe.SqlCeConnection.Open()
at System.Data.SqlServerCe.SqlCeConnection.Open()