作为SqlDataSource控件声明的一部分,你还要指定SelectCommand,InsertCommand,DeleteCommand,UpdateCommand和ConnectionString属性。这些xxxCommand属性允许你指定要被执行的SQL命令,而ConnectionString属性允许你指定用于连接到Pubs数据库的连接字符串;另外,这个值还可以从web.config文件中进行检索。因为该xxxCommand属性也包含SQL查询参数,所以,它们可以在DeleteParameters,UpdateParameters和InsertParameters模板中指定。
最后,声明一个GridView控件并且使用DataSourceID属性把GridView控件绑定到SqlDataSource控件上。通过把GridView的DataSourceID属性设置为SqlDataSource控件的ID,从SqlDataSource返回的数据就可以被自动地显示。
七、部分页面缓冲技术
到目前为止,你已经看到了如何在SqlDataSource控件中使用缓冲技术。本节将向你展示如何使用回寄方式缓存Substitution以便用刷新的内容替换被缓冲的内容部分。这称作“部分页面缓冲”或“页面片断缓冲”。这是一种强有力的特征,它允许应用程序使用页面级缓冲—即使该页面的部分是动态生成的。
页面片断缓冲提供对页面中一个片断进行缓冲的功能,这与缓冲整个页面形成对照。有时,整页面输出缓冲是不可行的—例如,当该页面的部分需要针对每一个用户请求动态地创建时。在这些情况下,标识出该页面或控件中不经常改变的部分以及那些需要耗费相应的服务器时间资源才能创建的部分可能是非常有价值的。在你标识这些部分后,你就能够把它们包装到一个Web表单用户控件中并且缓存该控件;这样以来,页面中的这些部分就不需要每次被重建。这是在ASP.NET 2.0以前实现页面片断缓冲的唯一方法。借助于ASP.NET 2.0中的新的回寄缓存Substitution特征,在页面呈现给用户之前,你可以通知ASP.NET运行时刻重新计算一个特定元素(正当它被生成到一个缓冲页面上时)。为此,你可以使用两种方案来实现这一目的:
◆调用新的Response.WriteSubstitution方法,同时传递一个到Substitution回调函数的引用。
◆把一个控件添加到Web页面并且把MethodName属性设置为该回调函数名。
无论使用哪种方案,你都需要在该页面的顶部放一条@Output缓存指令以指定相应的持续时间,而且该依赖性的其它的参数也应该被添加到该页面上。在这个示例中,我们选用Substitution控件。
该Substitution控件具有一个重要的属性—MethodName,它用于指定被调用以提供动态内容的方法。注意,Substitution控件调用的方法必须是一个静态方法。
而且,该方法必须有一个代表当前HttpContext的参数。为了说明这个问题,我们创建一个新的Web表单PartialPageCaching.aspx并把它添加到网站上。下面是示例PartialPageCaching.aspx相应的实现代码:
Partial Page Caching using Substitution controlThe random number generated is:The current time is. It never changes since thepage is cached.