RSS 2.0 Feed
SQL Server
摘要:【原文地址】Update of SQL Server Database Publishing Toolkit for Web Hosting 【原文发表日期】 Thursday, April 19, 2007 8:24 AM 几个月前,我在博客里写过由SQL服务器团队开发的新SQL 服务器数据库发布主机工具包 (SQL Server Database Publishing Hosting Toolkit)。你可以在我以前的2个博客贴子里读到关于它提供的功能和如何使用它的教程: Recipe: 把SQL数据库部署到远程主机环境 技巧和诀窍: 如何上传一个.SQL文件到远程主机并且执行它来部署一个SQL数据库 SQL服务器主机工具包是个可下载的免费工具,通过它来创建一个能重建你数据库(包括数据定义,存储过程,以及实际的数据内容)的.SQL脚本文件可真是容易之极。安装该工具完毕之后,你可以在 Visual Studio 或 Visual Web Developer 中右击你的数据库,然后使用相关的向导经过几个步骤来生成脚本: 然后你可以将该脚本通过FTP上传到你的远程主机环境中来执行(我上面第二个贴子示范了一个即使你在远程主机上没有管理员访问权限也可使用的技术)。或者,你也可以使用数据库发布向导提供的内置web服务支持,来直接导出和拷贝你的数据库到你的远程主机提供商那里。 SQL 服务器数据库发布工具包 V1.1 更新版 这个月早些时候,SQL团队推出了工具包的V1.1 更新版。你可以在这里了解相关细节以及下载更新版本。 V1.1 更新版包括了下列改进: 添加了在向导里发布时选择单个对象/数据表的能力(而不用每次都生成/重新生成数据库里的一切) 提高了生成脚本和发布时的性能 30-40% 做了在Internet上发布到主机提供商时可用性方面的改进 它修复了CodePlex论坛上提交的几个缺陷 我绝对建议你去看一下,如果你现在使用远程主机运行你的应用的话,这个免费工具是可以添置到工具箱去的绝对有用之物。 谢谢, Scott 标签: ASP.NET, .NET, SQL Server, 社区新闻 (Community News)...[阅读全文]

posted @ | Feedback (1) | Filed Under [ ASP.NET .NET SQL Server Community News ]

摘要:【原文地址】New "Orcas" Language Feature: Extension Methods【原文发表日期】 Tuesday, March 13, 2007 2:27 AM 上个星期,我发表了我准备写的讨论一些新的VB和C#语言特性的系列博客贴子的第一篇,这些新语言特性是将于今年晚些时候发布的Visual Studio和.NET框架Orcas版的一部分。 我的上一个博客贴子讨论了自动属性,对象初始化器和集合初始化器等新特性。如果你还没有读过这个帖子的话,请在这里阅读。今天的贴子讨论一个VB和C#中都具有的,重要得多的新特性:扩展方法 (Extension Methods)。 什么是扩展方法 (Extension Methods)? 扩展方法允许开发人员往一个现有的CLR类型的公开契约(contract)中添加新的方法,而不用生成子类或者重新编译原来的类型。扩展方法有助于把今天动态语言中流行的对duck typing的支持之灵活性,与强类型语言之性能和编译时验证融合起来。 扩展方法促成了好多有用的使用场景,并使在作为Orcas一部分发布的.NET版本中引进的非常强大的LINQ查询框架成为可能。 简单的扩展方法例子: 有没有想过要检查一个字符串变量是否是个合法的电子邮件地址? 在今天,你大概需要通过调用一个单独的类(或许通过一个静态方法)来实现检查该字符串变量是否合法。譬如,象这样: string email = Request.QueryString["email"];if ( EmailValidator.IsValid(email) ) {   } 而使用C#和VB中的新“扩展方法”语言特性的话,我则可以添加一个有用的“IsValidEmailAddress()”方法到string类本身中去,该方法返回当前字符串实例是否是个合法的字符串。然后我可以把我的代码重写一下,使之更加干净,而且更具描述性,象这样: string email = Request.QueryString["email"];if ( email.IsValidEmailAddress() ) {   } 我们是怎么把这个新的IsValidEmailAddress()方法添加到现有的string类里去的呢?我们是通过定义一个静态的类型,带有我们的“IsValidEmailAddress”这个静态的方法来实现的,象下面这样: public static class ScottGuExtensions{    public static bool IsValidEmailAddress(this string s)    {        Regex regex = new Regex(@"^[\w-\.]+@([\w-]+\.)+[\w-]{2,4}$");        return regex.IsMatch(s);    }} 注意,上面的静态方法在第一个类型是string的参数变量前有个“this”关键词,这告诉编译器,这个特定的扩展方法应该添加到类型为“string”的对象中去。然后在IsValidEmailAddress()方法实现里,我可以访问调用该方法的实际string实例的所有公开属性/方法/事件,取决于它是否是合法电子邮件地址来返回true/false。 在我的代码里把这个特定的扩展方法的实现添加到string实例,我只要使用标准的“using”语句来引入含有该扩展方法的实现的命名空间: using ScottGuExtensions; 然后编译器就会在任何string上正确地定位IsValidEmailAddress()方法。在公开发行的Orcas三月份的CTP中的C#和VB在Visual Studio代码编辑器里对扩展方法提供了完整的intellisense支持。所以,当我在一个字符串变量上点击“.”关键词时,我的扩展方法现在就会出现在intellisense的下拉框里: VB和C#编译器也会很自然地给与你对所有扩展方法用法的编译时的检查,这意味着你会得到一个编译时错误,假如你键错或者错用一个扩展方法的话。 [感谢David Hayden,是他在去年的一个老帖子 里第一个示范了我在上面使用的这个IsValidEmailAddress使用场景。] 扩展方法使用场景续... 利用扩展方法这个新特性来给个别类型添加方法给开发人员开辟了许多有用的扩展性使用场景。但使得扩展方法非常强有力的是,它们不仅能够应用到个别类型上,也能应用到.NET框架中任何基类或接口上。这允许开发人员建立种种可用于整个.NET框架的丰富的可组合的框架层扩展。 譬如,考虑这样一个场景,我想要一个既容易,描述性又强的方式来检查一个对象是否已经包含在一个对象集合或数组里。我可以定义一个简单的.In(集合)扩展方法,我想把它添加到.NET框架中的所有对象上,我可以在C#里这么来实现这个“In()”扩展方法: 注意上面我是如何声明扩展方法的第一个参数的:“this object o”。这表明,这个扩展方法应该适用于继承于基类System.Object的所有类型,这意味著我可以在.NET中的每个对象上使用它。 上面这个“In”方法的实现允许我检查一个指定的对象是否包含在作为方法参数传入的一个IEnumerable序列中。因为所有的.NET集合和数组都实现了IEnumerable接口,现在我拥有了一个有用的,描述性强的方法来检查一个任意的对象是否属于任何.NET集合或数组。 然后我就可以使用这个“In()”方法来看一个特定的字符串是否在一个字符串数组中: 我也可以用它来检查一个特定的ASP.NET控件是否在一个容器控件集合里: 我甚至可以将其用在象整数这样的标量数据类型上: 注意上面,你甚至可以在象整数值42这样的基本数据类型值上使用扩展方法。因为CLR支持数值类型的自动boxing/unboxing,扩展方法可以直接使用在数值和其他标量数据类型上。 你大概可以开始从上面的例子中看出,扩展方法可以促成一些非常丰富和描述性强的扩展性使用场景。当使用于.NET中常见的基类和接口上时,他们可以促成一些非常好的特定于某个领域(domain specific)的框架和组合使用场景。 内置的System.Linq扩展方法 一个在Orcas时段随.NET发布的内置的扩展方法库是一套允许开发人员对任何数据进行查询的非常强有力的查询扩展方法。这些扩展方法实现位于新的 System.Linq 命名空间之下,定义了标准的查询操作符扩展方法,可以为.NET开发人员用来轻松地查询XML,关系数据库,.NET 对象, 和任何其他数据结构类型。 ......[阅读全文]

posted @ | Feedback (39) | Filed Under [ ASP.NET .NET LINQ Data SQL Server ]

摘要:【原文地址】Free SQL Server Training Videos (and other good data tutorial pointers) 【原文发表日期】 Thursday, March 01, 2007 9:54 PM 今天在 www.asp.net 网站上,我们发布了一个注重于SQL Server 2005 Express 的新的精彩的《“我怎么做?”》录像系列,你可以下载和使用,是完全免费的。 系列中包括了13个专业录像,从最基本的开始,然后探讨数据表/数据定义(schema) 的设计,使用数据类型,创建存储过程,使用报表服务和商业智能引擎,对你的数据启用全文搜索等等。我猜,即使是大多数富有经验的开发人员也许也能从报表服务和全文搜索录像中学到一些新东西呢: 你可以在这里免费下载或在线观看这些SQL培训录像。 万一你错过了我写的关于把 SQL Express 或 SQL Server数据库上传到远程主机环境中的帖子的话,我强烈建议你回去读一下这2个贴子: Recipe: 把SQL数据库部署到远程主机环境(第一部分) 技巧和诀窍: 如何上传一个.SQL文件到远程主机并且执行它来部署一个SQL数据库 去年夏天早先时候,我曾贴出过一个很受欢迎的贴子,里面提供了你可以下载,在你应用中使用的100多个数据库数据定义的例子: Tip/Trick: Online Database Schema Samples Library (技巧/诀窍:在线数据库数据定义样例大全) 最后,也许是最重要的,一定要去看一下Scott Mitchell 这里的极棒的ASP.NET 数据教程系列 ,内含超过50个无比精彩的ASP.NET中常见的数据场景的教程(同时提供了VB 和C# 编码): 中文版:Scott Mitchell的ASP.NET2.0教程 (由MVP朱晔(lovecherry)主持翻译) 英文版:http://www.asp.net/learn/dataaccess/ 希望本文对你有所帮助, Scott 标签: ASP.NET, Data, SQL Server...[阅读全文]

posted @ | Feedback (5) | Filed Under [ ASP.NET Data SQL Server ]

摘要:【原文地址】 Tip/Trick: How to upload a .SQL file to a Hoster and Execute it to Deploy a SQL Database 【原文发表日期】 Thursday, January 11, 2007 12:20 AM 上个月 (英文),我讨论了新的(免费的)数据库发布向导,它是设计来充分简化在web主机环境中上传和部署 SQL Express 和 SQL Server数据库的。 在 第一个关于数据库发布的贴子 (英文)里 ,我示范了你如何可以使用数据库发布向导自动生成 .SQL 安装文件,该文件中将包含重建你的数据库数据定义(表,视图,存储过程,触发器,全文索引目录等等)以及以你原来数据库中同样的数据填充新数据库所需的脚本。这提供了一个极其容易的方法来构造在另外一个服务器上完全复制你的数据库的 .SQL 脚本: 在我以前的帖子里,我提到主机供应商经常提供在线SQL管理工具,你可以用它来打开/运行你新生成的 .SQL 文件,或者会提供SQL查询工具允许你拷贝/粘贴 .SQL 文件的内容到一个查询执行窗口来运行这些SQL语句。但不幸的是,并不是所有的主机供应商支持类似的工具。即使在那些支持类似工具的主机供应商那里,你也会遇上一些情形,譬如你生成的 .SQL 文件是如此之大,把它拷贝/粘贴进一个文本框是行不通的(提交一个 200M 字节内容的表单一般都会造成超时)。 这个帖子示范了把 .SQL 文件部署到远程主机环境中去的另外一个方法,这个方法不要求你的主机供应商在后端为你配置和安装任何东西。 不通过使用管理工具把SQL数据库部署到远程SQL服务器的步骤 下面是把一个本地数据库不通过使用任何管理工具就部署到远程主机上去的步骤: 第一步:生成一个包含数据定义和数据的 .SQL文件 远程部署数据库到主机环境的第一步是生成一个 .SQL 文件,内含你数据库的数据定义和数据。按我的 第一个关于数据库发布的博客帖子 (英文)里的步骤,来了解如何为 SQL Express 或 SQL Server数据库生成一个 .SQL 文件。 第二步: 把 .SQL 文件FTP到你的远程主机上去 生成 .SQL 文件之后,使用FTP或者其他文件传输机制将它上传到你的远程主机上去。最好是把这个文件拷贝到一个远程用户不易访问的受保护的场所。一个建议,给这个文件一个随机的名字,然后将它上传到 /app_data 文件夹,因为在默认情形下,该文件里的内容是受保护的。 用FTP来上传这个文件的好处是,它不会强迫你限制 .SQL 文件的大小。有必要的话,该文件的大小可达几百个M字节之多。 第三步: 下载 RunSQL.aspx 辅助页面 访问这个页面,下载其上连接的 RunSQL.aspx 文件。 RunSQL.aspx文件是个ASP.NET页面,是SQL Server产品组编写的,支持2个参数: 1) .SQL 文件的名字, 以及 2) 数据库的连接字符串。运行RunSQL.aspx页面,它会打开指定的 .SQL......[阅读全文]

posted @ | Feedback (5) | Filed Under [ ASP.NET .NET Tips and Tricks Data SQL Server ]

摘要:【原文地址】 Recipe: Deploying a SQL Database to a Remote Hosting Environment (Part 1) 【原文发表日期】 Friday, December 22, 2006 12:58 AM 场景: 你开发完了一个得意的ASP.NET应用,所有的东西都测试过了而且在你本机上一切工作都正常,充分利用了ASP.NET 2.0中的成员,角色和用户信息等新功能,万事俱备,准备将它发布到一个远程主机环境,跟整个世界分享这个应用。 将.aspx文件和编译的程序集拷贝到远程系统是非常容易的,只要使用FTP或者直接向上拷贝文件即可。但许多开发人员面临的挑战是,如何在远程主机的站点上架设和重建数据库内容,包括数据定义和数据本身。不幸的是,过去以来一直没有极其简单的方式来达成这个目的。 好消息是,这个星期,SQL Server产品组推出了新的 SQL Server Hosting Toolkit的发布候选版 ,这个工具包将使部署你的SQL解决方案到远程主机环境容易之极。这个工具包允许你在本地操作SQL Express,SQL Server 2000,和 SQL Server 2005数据库,然后把你的数据定义和数据轻松地迁移,安装到一个共享的远程主机SQL Server账号上。 下面的内容将描述你可以如何开始使用这个工具包。 SQL Server Hosting Toolkit SQL Server Hosting Toolkit可以免费获取,同时发布的还有一个数据库发布向导(Database Publishing Wizard),该向导支持2种数据库主机部署场景: 1) 数据库发布向导允许你指向一个你正在本机上操作的数据库,然后自动生成一个.SQL脚本文件,该文件包含了在任何远程系统上重建一个当前数据库的完整拷贝所需的安装逻辑。这个.SQL脚本包括了需要创建数据库定义(表,视图,存储过程,触发器,全文索引目录,角色,规则等等,可在此处参考所有细节),以及把与你本地数据库同样的数据内容填充到新数据库里去的所有的东西(这类似于MySQL 的dump工具)。把这些安装逻辑封装在单个.SQL 文件的好处是,大多数主机供应商已经支持上传 .SQL 文件到他们的主机环境,并且通过他们的管理控制面板运行这些脚本的能力。假定你现有一个支持这个功能的web主机供应商,你可以马上开始使用数据库发布向导来轻松地部署你的网站,而不需要主机供应商安装或配置什么东西。 2) 数据库发布向导也允许你指向一个你正在本机上操作的数据库,然后使用 web service 向你的远程主机环境迁移和重建数据库(而不用创建一个.SQL 文件或者使用主机供应商的管理控制面板运行这个文件)。不过,这个发布选项需要主机环境提供SQL发布web-service。 SQL Server Hosting Toolkit包含了一个免费的SQL发布web-service实现,我们将与主机供应商密切合作来部署这个web-service。 数据库发布向导允许你在本地使用 SQL Express 或 SQL Server 2000/2005 ,然后在远程主机环境中使用SQL 2000 或 SQL 2005。它不要求SQL服务器的版本是一样的,所以,你可以在本地使用SQL Express 2005,然后上传到主机环境中的SQL 2000服务器,而不用改动任何编码。 数据库发布向导也支持对内置的ASP.NET 2.0成员,角色管理,用户信息和健康监测等数据定义的处理。许多人遇上问题,因为随 ASP.NET一起发布的来建立这些数据定义的内置.SQL 脚本在安装时(install-time)需要DBO权限,但很多主机供应商对此并不支持(注:脚本在运行时(runtime)不需要DBO权限,只是在安装时(install time)才需要,但这有时会是个障碍,除非主机供应商愿意为你安装)。而在另一方面,数据库发布向导在安装ASP.NET 2.0成员,角色管理,用户信息等数据定义和数据时,并不需要DBO权限,应该允许你,和使用数据库发布向导部署其他数据库一样,轻松地部署 ASPNETDB数据表和存储过程。 教程一:使用.SQL文件把SQL Express数据库部署到一个SQL Server主机账号上去 在接下来的几周内,我将写一系列的帖子示范如何使用SQL Server Hosting Toolkit中的种种功能。这系列中的第一个教程讨论如何使用它来轻松地生成一个本地SQL Express数据库的 .SQL 安装文件,然后你可以将它拷贝到一个远程主机账号上,用它来重新建立一个......[阅读全文]

posted @ | Feedback (17) | Filed Under [ ASP.NET .NET Visual Studio Tips and Tricks Data SQL Server ]

摘要:【原文地址】Visual Studio for Database Professionals and other Cool Data Management Tools for .NET 【原文发表日期】 Wednesday, October 18, 2006 7:40 AM 今天早先时候,我们发布了Visual Studio Team版的数据库专业人员版的第六个社区技术预览版(CTP)供免费下载。  Visual Studio 数据库专业人员版获得的好评如潮,其功能包括对数据库重构,数据库定义和数据的比较,数据库单元测试,以及自动的数据生成的支持。你可以在它的MSDN开发人员中心及其社区网页上了解更多的相关信息。你也可以在这里观看一个 Channel9 采访该产品开发组的录像。 我最近在 http://weblogs.asp.net 上看到了另外2个数据管理工具,看上去非常酷,值得花时间看一下: MassDataHandler  ──  一个免费的CodePlex项目,提供了一个可以为单元测试自动生成数据的工具库,可以和任何单元测试框架一起使用。 Data Dictionary Creator  ──  一个免费的工具,可以帮助你管理SQL服务器数据库的文档,帮你把文档与数据定义的变动保持同步。 希望本文对你有所帮助, Scott 标签: ASP.NET, Visual Studio, .NET, SQL Server...[阅读全文]

posted @ | Feedback (3) | Filed Under [ ASP.NET .NET Visual Studio SQL Server ]