Microsoft CSIP WindowsMobile MEDC 合作伙伴 体验中心 设Winbile为首页 加Winbile到收藏夹

 
登录       点击换一张     注册新用户 找回密码

如何将数据导入到 SQL Server Compact Edition 数据库中
2008年03月18日11:48   作者:黎波 来源: 博客 浏览: 475

摘要:在本系列文章中,我已经尝试在 Windows 桌面平台和 Windows Mobile 平台上将数据导入到 SQL Server Compact Edition 数据库中。不过,之前的示例程序都属于 Windows 应用程序。本文将介绍如何在 ASP.NET Web 应用程序中实现 SQL Server Compact Edition 数据库的生成和数据导入。

一、创建 ASP.NET 版的数据导入程序

1.使用 Visual Studio 2005 新建一个 Visual C# 版本的“ASP.NET Web 应用程序”项目,项目名称为“CopyTableASPNET”。

2.为新建的“CopyTableASPNET”项目添加对 System.Data.SqlServerCe.dll 程序集的引用,注意版本号是 9.0.242.0。这里特别声明版本号是考虑到大家可能安装了 Visual Studio 2008,它自带了最新的 SQL Server Compact 3.5,版本号是 3.5.0.0,可能也会出现在添加引用对话框中。而本文的示例是针对 SQL Server 2005 Compact Edition (v3.1) 编写的,程序集版本号为 9.0.242.0。



3.在“解决方案资源管理器”打开 Default.aspx 页面,默认显示的是 HTML 代码视图,需要切换到设计视图。从工具箱拖拽一个 Button 控件到页面上,修改其 Text 属性为“生成 SQL Server Compact 数据库”。

4.打开 Default.aspx 页面的 C# 代码编辑视图,或者直接打开 Default.aspx.cs 文件。从本系列文章第四篇的示例代码中,复制 From1.cs 文件的 GetTableNames, CopyTable, VerifyDatabaseExists, GenerateTableSchemaSql, GetSqlCeDataType 和 GetSqlCeNativeType 等方法到 Default.aspx.cs 文件中。

5.回到 Default.aspx 页面的设计视图,用鼠标双击 Button 控件,此时会跳到 Default.aspx.cs 的代码编辑视图,并生成了 Button 控件的 Click 事件处理方法。将以下代码复制到 Click 事件处理方法中:

// 创建源 SQL Server 数据库连接对象
string srcConnString = "Data Source=(local);Initial Catalog=Northwind;Integrated Security=True";
SqlConnection srcConnection
= new SqlConnection(srcConnString);

// 创建目标 SQL Server Compact Edition 数据库连接对象
string destConnString = string.Format("Data Source={0};", Server.MapPath("Northwind.sdf"));
SqlCeConnection destConnection
= new SqlCeConnection(destConnString);

VerifyDatabaseExists(destConnString);

srcConnection.Open();
destConnection.Open();

// 复制数据
string[] tableNames = GetTableNames(srcConnection);
string query;
for (int i = 0; i < tableNames.Length; i++)
{
    query
= string.Format("SELECT * FROM [{0}]", tableNames[i]);
    CopyTable(srcConnection, destConnection, query, tableNames[i]);
}

srcConnection.Close();
destConnection.Close();

// 重定向到生成的 Northwind.sdf 文件的 url 地址(使浏览器提示下载)
Response.Redirect("Northwind.sdf");

这段代码跟本系列文章第四篇的示例代码非常相似,大家注意代码中加亮的语句。

6.数据导入的代码已经编写完成,现在可以生成项目,并在浏览器中查看 Default.aspx 页面。



出错了!到底是什么原因呢?

二、解锁 SQL Server Compact Edition 对 ASP.NET 的支持

我在《SQL Server精简版支不支持ASP.NET?》曾经探讨过这个问题。“当前 SQL Server Compact Edition 并未针对网站数据库用途进行优化。默认情况下,在 SQL Server Compact Edition 中阻塞了来自 ASP.NET 应用程序的连接。SQL Server Compact Edition 经过优化后,可在应用程序中作为嵌入数据库使用。使用 SQL Server Compact Edition 作为网站数据库要求支持多用户和并发数据更改。这可能会导致性能问题。因此,不支持这些情形。其他版本的 SQL Server 2005(包括 SQL Server 2005 Express Edition)经过优化后,也可作为网站数据库使用。在使用 ASP.NET 创建 SQL Server Compact Edition 数据库以实现同步操作的应用方案中,SQL Server Compact Edition 可与 ASP.NET 配合使用。使用下列代码更改 SQL Server Compact Edition 的默认行为,以便与 ASP.NET 配合使用:AppDomain.CurrentDomain.SetData("SQLServerCompactEditionUnderWebHosting", true)”——引自《SQL Server 2005 Compact Edition 联机丛书》

7.为了解决步骤6出现的错误,我在 Default.aspx 页面上添加一个 CheckBox 控件 chkEnableSqlCe,并将它的 Text 属性设置为“允许在 ASP.NET 使用 SQL Server Compact”。在 Default.aspx.cs 的 Page_Load 方法中添加


12末页下一页

发表评论
评论标题 :
评论内容 :

    查看评论

请您注意:遵守国家有关法律、法规,尊重网上道德,承担一切因您的行为而直接或间接引起的法律责任。 本站拥有管理笔名和留言的一切权利。
相关文章推荐
· Windows Mobile Test Framework简介 2007-10-10  张欣

  

论坛推荐  
热点活动
更多»

© CSIP 信息产业部软件与集成电路促进中心 All Rights Reserved 版权所有 京ICP备06020771号
联系电话:010-63951881-8003 王先生        邮件:wangj@csip.org.cn