控件中国网现已改版,您看到的是老版本网站的镜像,系统正在为您跳转到新网站首页,请稍候.......
中国最专业的商业控件资讯网产品咨询电话:023-67870900 023-67871946
产品咨询EMAIL:SALES@COMPONENTCN.COM

.NET Campact Framework下SQL CE兼容性问题

作者:Jake.NET 出处:博客园 2010年01月27日 阅读:

在.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()

 

 

如果使用3.0的SqlServerCe.dll访问3.5的sdf数据文件会有以下异常

System.Data.SqlServerCe.SqlCeInvalidDatabaseFormatException : Unspecified error
at System.Data.SqlServerCe.SqlCeConnection.ProcessResults()
at System.Data.SqlServerCe.SqlCeConnection.Open()
at System.Data.SqlServerCe.SqlCeConnection.Open()

 

解决方法


由于在CF.NET下开发SQL CE 3.0和3.5的代码是一样,可以参考 .NET Compact Framework下SQL CE的使用 ,所以最简单的解决方法是升级3.0到3.5,这样原先使用3.0的程序可以在不修改源码的情况下使用3.5。

数据文件升级

使用vs2008打开3.0的sdf文件

 
 点击OK进行升级。
 
程序引用的升级

在项目的引用中删除System.Data.SqlServerCe的引用,添加 C:\Program Files\Microsoft SQL Server Compact Edition\v3.5\Devices\System.Data.SqlServerCe.dll到新引用。

  

在设备上安装SQL CE 3.5

下载SQL CE 3.5 可参考 SQL Server Express和SQL Server Compact的应用, 安装后可以在 C:\Program Files\Microsoft SQL Server Compact Edition\v3.5\Devices\wce500下选择相应的硬件平台进行安装。
 

 
 初步试了一下,natice的C++代码不能源码级支持两个不同的版本,需要进一步的研究才知道原因。(本文由控件中国网转载)

 

热推产品

  • ActiveReport... 强大的.NET报表设计、浏览、打印、转换控件,可以同时用于WindowsForms谀坔攀戀Forms平台下......
  • AnyChart AnyChart使你可以创建出绚丽的交互式的Flash和HTML5的图表和仪表控件。可以用于仪表盘的创......
首页 | 新闻中心 | 产品中心 | 技术文档 | 友情连接 | 关于磐岩 | 技术支持中心 | 联系我们 | 帮助中心 Copyright-2006 ComponentCN.com all rights reserved.重庆磐岩科技有限公司(控件中国网) 版权所有 电话:023 - 67870900 传真:023 - 67870270 产品咨询:sales@componentcn.com 渝ICP备12000264号 法律顾问:元炳律师事务所 重庆市江北区塔坪36号维丰创意绿苑A座28-5 邮编:400020
在线客服
在线客服系统
在线客服
在线客服系统