系列文章导航:
如何将数据导入到 SQL Server Compact Edition 数据库中(一)
如何将数据导入到 SQL Server Compact Edition 数据库中(二)
如何将数据导入到 SQL Server Compact Edition 数据库中(三)
如何将数据导入到 SQL Server Compact Edition 数据库中(四)
摘要:在本系列文章中,我已经尝试在 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 方法中添加以下代码:
if(chkEnableSqlCe.Checked)
{
AppDomain.CurrentDomain.SetData("SQLServerCompactEditionUnderWebHosting",true);
}
else
{
AppDomain.CurrentDomain.SetData("SQLServerCompactEditionUnderWebHosting",false);
}
8.重新编译项目,并浏览 Default.aspx 页面。页面加载完成后,选中“允许在 ASP.NET 使用 SQL Server Compact”检查框,再点击“生成 SQL Server Compact 数据库”按钮。此时,Default.aspx 页面将在后台生成 SQL Server Compact Edition 数据库文件 Northwind.sdf,并从 SQL Server 服务器的 Northwind 数据库导入数据,最后将提示您下载 Northwind.sdf 文件。
三、总结
在很多场景中,我们可以使用 ASP.NET 根据各种条件在服务器端快速生成 SQL Server Compact Edition 数据库文件(.sdf),并从数据库服务器导入初始数据,再将动态生成的数据库文件提供给客户端程序下载。这样可以加速和简化 Windows Mobile 应用程序初始化本地数据库的过程,因为只需要传输文件而不需要进行复杂的数据同步。本文介绍的方案并没有结束,实际上 SQL Server Compact Edition 数据库文件的压缩率是很高的。例如:本文的示例代码生成的 Northwind.sdf 文件是 788 KB,经过 ZIP 标准压缩后生成的 Northwind.zip 文件是 228 KB。为了减少数据传输流量,同时也是为了节约时间,我们还可以对生成的数据库文件进行压缩后,再提供给客户端下载,客户端再对文件进行解压缩。
示例代码下载:sqlce_data_import5.rar
作者:黎波
博客:http://upto.cnblogs.com/
日期:2008年3月5日
分享到:
相关推荐
excel数据导入到sql server数据库中,
将Excel数据导入到SQLServer中,可以选择要导入的Excel文件和Sheet名称,表名。通过自动编写存储过程来实现导入功能。实际使用无须这么麻烦,可以作为数据导入和存储过程参考例子。
Oracle数据库导入到SqlServer步骤(图文篇),自己写的,碰到不少问题,终于解决了。
该文档实现将access数据库中的表中的所有数据导入到sqlserver2005数据库
利用 Microsoft SQL Server Migration Assistant for Oracle.exe(微软数据库迁移工具) ,将oracle数据库迁移数据到SQL server详解。
将mysql数据库转换为sql server的数据库,或者将sql server数据库转换...这里介绍一个使用sql的mmc的方法 ,将sql server的数据转化为mysql的数据库,将源和目的反之,就可以将mysql的数据库转化为sql server的数据库。
怎样将Excel中的数据导入到SQL Server 2000数据库中
利用EXCEL中的宏,直接将excel中的数据导入到sqlServer数据库脚本
vs打开或创建工程时,弹框出现"创建或打开浏览数据库文件时发生错误。Intellisense和浏览信息江不能用于C++项目。请确保已安装Microsoft SQL Server Compact 3.5",并且类向导打不开。安装后可解决上述问题。
有时候我们可能会把CSV中的数据导入到某个数据库的表中,比如做报表分析的时候。 对于这个问题,我想一点也难不倒程序人员吧!但是要是SQL Server能够完成这个任务,岂不是更好! 对,SQL Server确实有这个功能。 ...
实现MAPINFO MIF数据导入到SQL SERVER数据库中
利用C#编程将Excel中的数据导入到Sqlserver数据库中
向sql server数据库插入中文时显示乱码
精简版SQL Server 2005 数据库导出、导入办法 应该有用~
将Mysql数据库导入到SQLSERVER里面
oracle数据库导入数据到sql server数据库操作步骤说明文档
谈谈数据从sql server数据库导入mysql数据库的体验
很多时候需要我们把Excel中的数据快速导入到Sqlserver数据库中,但是sqlserver自带的代入很麻烦,而且速度很慢,一旦电脑配置低 就得卡死,我做的这个小程序可以十分迅速的把数据导入到您想要导入的表中,很方便。
将sqlserver数据导入MySql中的工具,里面附带说明