系列文章导航: 如何将数据导入到 SQL Server Compact Edition 数据库中(一) 如何将数据导入到 SQL Server Compact Edition 数据库中(二) 如何将数据导入到 SQL Server Compact Edition 数据库中(三) 如何将数据导入到 SQL Server Compact Edition 数

系列文章导航:

如何将数据导入到 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 数据库连接对象stringsrcConnString="Data Source=(local);Initial Catalog=Northwind;Integrated Security=True";

SqlConnection srcConnection=newSqlConnection(srcConnString);//创建目标 SQL Server Compact Edition 数据库连接对象stringdestConnString=string.Format("Data Source={0};", Server.MapPath("Northwind.sdf"));

SqlCeConnection destConnection=newSqlCeConnection(destConnString);

VerifyDatabaseExists(destConnString);

srcConnection.Open();

destConnection.Open();//复制数据string[] tableNames=GetTableNames(srcConnection);stringquery;for(inti=0; 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日

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

sql compact 转mysql_如何将数据导入到 SQL Server Compact Edition 数据库中(五)相关推荐

  1. sql compact 转mysql_如何将数据导入到 SQL Server Compact Edition 数据库中(三)

    系列文章导航: 如何将数据导入到 SQL Server Compact Edition 数据库中(一) 如何将数据导入到 SQL Server Compact Edition 数据库中(二) 摘要:时 ...

  2. sql compact 转mysql_如何将数据导入到 SQL Server Compact Edition 数据库中(四)

    系列文章导航: 如何将数据导入到 SQL Server Compact Edition 数据库中(一) 如何将数据导入到 SQL Server Compact Edition 数据库中(二) 如何将数 ...

  3. 如何将数据导入到 SQL Server Compact Edition 数据库中(四)

    系列文章导航: 如何将数据导入到 SQL Server Compact Edition 数据库中(一) 如何将数据导入到 SQL Server Compact Edition 数据库中(二) 如何将数 ...

  4. 将excel数据导入到SQL server数据库,SQL server引入导入excel报表,如何解决“未在本地计算机上注册“Microsoft.ACE.OLEDB.12.0”提供程序”问题

    目录 版本: 文章主要内容: 未在本地计算机上注册"Microsoft.ACE.OLEDB.12.0"提供程序 新版本不同的设置的地方: 版本: SQL server2018.ex ...

  5. SQL点滴12—SQL Server备份还原数据库中的小把戏

    原文:SQL点滴12-SQL Server备份还原数据库中的小把戏 备份数据库时出现一个不太了解的错误 ,错误信息"is formatted to support  1 media fami ...

  6. java sqlldr导入_使用SQL*LOADER将TXT或CSV数据导入ORACLE(转)

    一.简介 SQL*LOADER是ORACLE的数据加载工具,通常用来将操作系统文件迁移到ORACLE数据库中.SQL*LOADER是大型数据仓库选择使用的加载方法,因为它提供了最快速的途径(DIREC ...

  7. excel导入mysql语句_求助:用SQL语句从Excel将数据导入到SQL数据库

    这个是Excel的,比如是test.xls 欠费年份 欠费开始月份 欠费结束月份 应缴金额(月租) 2001             9                 12            9 ...

  8. 超大Sql文件_超大文件_mysql数据导入到mycat数据库_亲测好用---Linux运维工作笔记053

    对于mycat数据导入,最近一直在研究,因为有个客户的mysql数据库中,单表数据已经30多个GB, 存了上亿条的数据. 查询速度远远跟不上需求了,这个时候,我做了一个mycat集群,用了22台cen ...

  9. 怎样将Excel中的数据导入到SQL Server 2000数据库中

    1.打开企业管理器,打开要导入数据的数据库,在表上按右键,所有任务-->导入数据,弹出DTS导入/导出向导,按 下一步 , 2.选择数据源 Microsoft Excel 97-2000,文件名 ...

最新文章

  1. 判断jQuery库是否被正确引入
  2. Blender创建三维教室场景学习教程 3D Classroom Environment Creation in Blender
  3. linux 分析 进程cpu占用过高
  4. cf534D 枚举握手次数
  5. Mind Master Pro 8.0——安装教程
  6. linux如何在a休息时运行b,Linux下如何优雅地修正命令?
  7. Alpha冲刺博客集
  8. java8根据某个id删选_Java 8可选:如何使用它
  9. matlab画图显示中文
  10. 2030年春节,你会跟机器人一起过吗?
  11. 每个程序员都应该知道的5个定律
  12. php 5.6.29,源码编译安装PHP 5.6.29
  13. 一个测试的日常:对于python装饰器的理解(个人心得及体会)
  14. 网络基础虚拟化VRRP/MSTP冗余技术
  15. js加密php解密---jsencrypt
  16. 80c51单片机c语言程序,80C51单片机电子钟程序
  17. ssdt函数索引号_shadow ssdt 服务表函数索引
  18. 判断电路是正反馈还是负反馈,电流反馈还是电压反馈
  19. 底物的分子描述符计算及 CYP450 酶-底物选择性技术研究
  20. 嵌入式课程设计linux,嵌入式课程设计报告

热门文章

  1. 这台笔记本最适合程序员编程!
  2. 一条简单的sql语句导致的系统问题(r4笔记第51天)
  3. unexpected character `w‘ in type specifier 解决方案
  4. 计算机开机后黑屏鼠标显示桌面图标,电脑开机后黑屏怎么解决只显示鼠标
  5. 2021数学建模国赛B题复盘详细解析
  6. 手机中的照片不见了如何恢复
  7. Android studio如何导入导出手机和模拟器文件
  8. Mint家族迎来了“瑟瑞娜”
  9. pygame用blit()实现动画效果
  10. excel如何选中从当前单元格第一行跳到内容最后一行或者从选的最后一行跳到第一行