<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
		<id>http://nfex.ru/index.php?action=history&amp;feed=atom&amp;title=ASP.NET_Tutorial%2FCache%2FSQL_Cache_Dependencies</id>
		<title>ASP.NET Tutorial/Cache/SQL Cache Dependencies - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://nfex.ru/index.php?action=history&amp;feed=atom&amp;title=ASP.NET_Tutorial%2FCache%2FSQL_Cache_Dependencies"/>
		<link rel="alternate" type="text/html" href="http://nfex.ru/index.php?title=ASP.NET_Tutorial/Cache/SQL_Cache_Dependencies&amp;action=history"/>
		<updated>2026-04-29T18:55:08Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://nfex.ru/index.php?title=ASP.NET_Tutorial/Cache/SQL_Cache_Dependencies&amp;diff=2895&amp;oldid=prev</id>
		<title> в 15:30, 26 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://nfex.ru/index.php?title=ASP.NET_Tutorial/Cache/SQL_Cache_Dependencies&amp;diff=2895&amp;oldid=prev"/>
				<updated>2010-05-26T15:30:57Z</updated>
		
		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr style=&quot;vertical-align: top;&quot; lang=&quot;ru&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;← Предыдущая&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;Версия 15:30, 26 мая 2010&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; style=&quot;text-align: center;&quot; lang=&quot;ru&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(нет различий)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
			</entry>

	<entry>
		<id>http://nfex.ru/index.php?title=ASP.NET_Tutorial/Cache/SQL_Cache_Dependencies&amp;diff=2896&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://nfex.ru/index.php?title=ASP.NET_Tutorial/Cache/SQL_Cache_Dependencies&amp;diff=2896&amp;oldid=prev"/>
				<updated>2010-05-26T11:57:24Z</updated>
		
		<summary type="html">&lt;p&gt;1 версия&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Новая страница&lt;/b&gt;&lt;/p&gt;&lt;div&gt;== SqlDependency (C#)==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;%@ Page Language=&amp;quot;C#&amp;quot; AutoEventWireup=&amp;quot;true&amp;quot;  CodeFile=&amp;quot;Default.aspx.cs&amp;quot; Inherits=&amp;quot;_Default&amp;quot; %&amp;gt;&lt;br /&gt;
&amp;lt;!DOCTYPE html PUBLIC &amp;quot;-//W3C//DTD XHTML 1.0 Transitional//EN&amp;quot; &amp;quot;http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;html xmlns=&amp;quot;http://www.w3.org/1999/xhtml&amp;quot; &amp;gt;&lt;br /&gt;
&amp;lt;head runat=&amp;quot;server&amp;quot;&amp;gt;&lt;br /&gt;
    &amp;lt;title&amp;gt;Untitled Page&amp;lt;/title&amp;gt;&lt;br /&gt;
&amp;lt;/head&amp;gt;&lt;br /&gt;
&amp;lt;body&amp;gt;&lt;br /&gt;
    &amp;lt;form id=&amp;quot;form1&amp;quot; runat=&amp;quot;server&amp;quot;&amp;gt;&lt;br /&gt;
    &amp;lt;div&amp;gt;&lt;br /&gt;
        &amp;lt;asp:GridView ID=&amp;quot;GridView1&amp;quot; runat=&amp;quot;server&amp;quot; Height=&amp;quot;400px&amp;quot; Width=&amp;quot;400px&amp;quot;&amp;gt;&lt;br /&gt;
        &amp;lt;/asp:GridView&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
    &amp;lt;/div&amp;gt;&lt;br /&gt;
    &amp;lt;/form&amp;gt;&lt;br /&gt;
&amp;lt;/body&amp;gt;&lt;br /&gt;
&amp;lt;/html&amp;gt;&lt;br /&gt;
File: Default.aspx.cs&lt;br /&gt;
using System;&lt;br /&gt;
using System.Data;&lt;br /&gt;
using System.Data.SqlClient;&lt;br /&gt;
using System.Web.Caching;&lt;br /&gt;
using System.Configuration;&lt;br /&gt;
using System.Web;&lt;br /&gt;
using System.Web.Security;&lt;br /&gt;
using System.Web.UI;&lt;br /&gt;
using System.Web.UI.WebControls;&lt;br /&gt;
using System.Web.UI.WebControls.WebParts;&lt;br /&gt;
using System.Web.UI.HtmlControls;&lt;br /&gt;
public partial class _Default : System.Web.UI.Page &lt;br /&gt;
{&lt;br /&gt;
    protected void Page_Load(object sender, EventArgs e)&lt;br /&gt;
    {&lt;br /&gt;
        Response.Write(&amp;quot;Page created: &amp;quot; + DateTime.Now.ToLongTimeString());&lt;br /&gt;
        string connStr = ConfigurationManager.ConnectionStrings[&amp;quot;AppConnectionString1&amp;quot;].ConnectionString;&lt;br /&gt;
        SqlDependency.Start(connStr);&lt;br /&gt;
        SqlConnection connection = new SqlConnection(connStr);&lt;br /&gt;
        SqlCommand command = new SqlCommand(&amp;quot;Select * FROM Customers&amp;quot;, connection);&lt;br /&gt;
        SqlCacheDependency depends = new SqlCacheDependency(command);&lt;br /&gt;
        &lt;br /&gt;
        connection.Open();&lt;br /&gt;
        GridView1.DataSource = command.ExecuteReader();&lt;br /&gt;
        GridView1.DataBind();&lt;br /&gt;
        connection.Close();&lt;br /&gt;
        Response.AddCacheDependency(depends);&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
File: Web.config&lt;br /&gt;
&amp;lt;?xml version=&amp;quot;1.0&amp;quot;?&amp;gt;&lt;br /&gt;
&amp;lt;configuration&amp;gt;&lt;br /&gt;
  &amp;lt;appSettings/&amp;gt;&lt;br /&gt;
  &amp;lt;connectionStrings&amp;gt;&lt;br /&gt;
    &amp;lt;add name=&amp;quot;AppConnectionString1&amp;quot; connectionString=&amp;quot;Data Source=.\SQLEXPRESS;User ID=wrox;Password=wrox1*c;Database=Northwind;Persist Security Info=False&amp;quot; providerName=&amp;quot;System.Data.SqlClient&amp;quot;/&amp;gt;&lt;br /&gt;
  &amp;lt;/connectionStrings&amp;gt;&lt;br /&gt;
  &amp;lt;system.web&amp;gt;&lt;br /&gt;
    &amp;lt;compilation debug=&amp;quot;true&amp;quot; strict=&amp;quot;false&amp;quot; explicit=&amp;quot;true&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;pages&amp;gt;&lt;br /&gt;
      &amp;lt;namespaces&amp;gt;&lt;br /&gt;
        &amp;lt;clear/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Collections&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Collections.Specialized&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Configuration&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Text&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Text.RegularExpressions&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web.Caching&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web.SessionState&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web.Security&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web.Profile&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web.UI&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web.UI.WebControls&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web.UI.WebControls.WebParts&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web.UI.HtmlControls&amp;quot;/&amp;gt;&lt;br /&gt;
      &amp;lt;/namespaces&amp;gt;&lt;br /&gt;
    &amp;lt;/pages&amp;gt;&lt;br /&gt;
    &amp;lt;authentication mode=&amp;quot;Windows&amp;quot;/&amp;gt;&lt;br /&gt;
  &amp;lt;/system.web&amp;gt;&lt;br /&gt;
&amp;lt;/configuration&amp;gt;&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== SqlDependency=&amp;quot;Northwind:Customers&amp;quot;==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;%@ Page Language=&amp;quot;C#&amp;quot; AutoEventWireup=&amp;quot;true&amp;quot;%&amp;gt;&lt;br /&gt;
&amp;lt;%@ OutputCache Duration=&amp;quot;30&amp;quot; VaryByParam=&amp;quot;none&amp;quot; SqlDependency=&amp;quot;Northwind:Customers&amp;quot;%&amp;gt;&lt;br /&gt;
&amp;lt;script runat=&amp;quot;server&amp;quot;&amp;gt;&lt;br /&gt;
    protected void Page_Load(object sender, System.EventArgs e) &lt;br /&gt;
    {&lt;br /&gt;
        Label1.Text = &amp;quot;Page created at &amp;quot; + DateTime.Now.ToShortTimeString();&lt;br /&gt;
    }&lt;br /&gt;
&amp;lt;/script&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;html xmlns=&amp;quot;http://www.w3.org/1999/xhtml&amp;quot; &amp;gt;&lt;br /&gt;
&amp;lt;head id=&amp;quot;Head1&amp;quot; runat=&amp;quot;server&amp;quot;&amp;gt;&lt;br /&gt;
    &amp;lt;title&amp;gt;Sql Cache Invalidation&amp;lt;/title&amp;gt;&lt;br /&gt;
&amp;lt;/head&amp;gt;&lt;br /&gt;
&amp;lt;body&amp;gt;&lt;br /&gt;
    &amp;lt;form id=&amp;quot;form1&amp;quot; runat=&amp;quot;server&amp;quot;&amp;gt;&lt;br /&gt;
        &amp;lt;asp:Label ID=&amp;quot;Label1&amp;quot; Runat=&amp;quot;server&amp;quot;&amp;gt;&amp;lt;/asp:Label&amp;gt;&amp;lt;br /&amp;gt;&lt;br /&gt;
        &amp;lt;br /&amp;gt;&lt;br /&gt;
        &amp;lt;asp:GridView ID=&amp;quot;GridView1&amp;quot; Runat=&amp;quot;server&amp;quot; DataSourceID=&amp;quot;SqlDataSource1&amp;quot;&amp;gt;&lt;br /&gt;
        &amp;lt;/asp:GridView&amp;gt;&lt;br /&gt;
        &amp;lt;asp:SqlDataSource ID=&amp;quot;SqlDataSource1&amp;quot; Runat=&amp;quot;server&amp;quot; &lt;br /&gt;
         SelectCommand=&amp;quot;Select * From Customers&amp;quot;&lt;br /&gt;
         ConnectionString=&amp;quot;&amp;lt;%$ ConnectionStrings:AppConnectionString1 %&amp;gt;&amp;quot; &lt;br /&gt;
         ProviderName=&amp;quot;&amp;lt;%$ ConnectionStrings:AppConnectionString1.providername %&amp;gt;&amp;quot;&amp;gt;&lt;br /&gt;
        &amp;lt;/asp:SqlDataSource&amp;gt;&lt;br /&gt;
    &amp;lt;/form&amp;gt;&lt;br /&gt;
&amp;lt;/body&amp;gt;&lt;br /&gt;
&amp;lt;/html&amp;gt;&lt;br /&gt;
File: Web.config&lt;br /&gt;
&amp;lt;?xml version=&amp;quot;1.0&amp;quot;?&amp;gt;&lt;br /&gt;
&amp;lt;configuration&amp;gt;&lt;br /&gt;
  &amp;lt;appSettings/&amp;gt;&lt;br /&gt;
  &amp;lt;connectionStrings&amp;gt;&lt;br /&gt;
    &amp;lt;add name=&amp;quot;AppConnectionString1&amp;quot; connectionString=&amp;quot;Data Source=.\SQLEXPRESS;User ID=wrox;Password=wrox1*c;Database=Northwind;Persist Security Info=False&amp;quot; providerName=&amp;quot;System.Data.SqlClient&amp;quot;/&amp;gt;&lt;br /&gt;
  &amp;lt;/connectionStrings&amp;gt;&lt;br /&gt;
  &amp;lt;system.web&amp;gt;&lt;br /&gt;
    &amp;lt;caching&amp;gt;&lt;br /&gt;
      &amp;lt;sqlCacheDependency enabled=&amp;quot;true&amp;quot;&amp;gt;&lt;br /&gt;
        &amp;lt;databases&amp;gt;&lt;br /&gt;
          &amp;lt;add name=&amp;quot;Northwind&amp;quot; connectionStringName=&amp;quot;AppConnectionString1&amp;quot; pollTime=&amp;quot;500&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;/databases&amp;gt;&lt;br /&gt;
      &amp;lt;/sqlCacheDependency&amp;gt;&lt;br /&gt;
    &amp;lt;/caching&amp;gt;&lt;br /&gt;
    &amp;lt;compilation debug=&amp;quot;true&amp;quot; strict=&amp;quot;false&amp;quot; explicit=&amp;quot;true&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;pages&amp;gt;&lt;br /&gt;
      &amp;lt;namespaces&amp;gt;&lt;br /&gt;
        &amp;lt;clear/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Collections&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Collections.Specialized&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Configuration&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Text&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Text.RegularExpressions&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web.Caching&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web.SessionState&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web.Security&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web.Profile&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web.UI&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web.UI.WebControls&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web.UI.WebControls.WebParts&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web.UI.HtmlControls&amp;quot;/&amp;gt;&lt;br /&gt;
      &amp;lt;/namespaces&amp;gt;&lt;br /&gt;
    &amp;lt;/pages&amp;gt;&lt;br /&gt;
    &amp;lt;authentication mode=&amp;quot;Windows&amp;quot;/&amp;gt;&lt;br /&gt;
  &amp;lt;/system.web&amp;gt;&lt;br /&gt;
&amp;lt;/configuration&amp;gt;&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== SqlDependency (VB)==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;%@ Page Language=&amp;quot;VB&amp;quot; AutoEventWireup=&amp;quot;false&amp;quot; CodeFile=&amp;quot;Default.aspx.vb&amp;quot; Inherits=&amp;quot;_Default&amp;quot; %&amp;gt;&lt;br /&gt;
&amp;lt;!DOCTYPE html PUBLIC &amp;quot;-//W3C//DTD XHTML 1.0 Transitional//EN&amp;quot; &amp;quot;http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;html xmlns=&amp;quot;http://www.w3.org/1999/xhtml&amp;quot; &amp;gt;&lt;br /&gt;
&amp;lt;head runat=&amp;quot;server&amp;quot;&amp;gt;&lt;br /&gt;
    &amp;lt;title&amp;gt;Untitled Page&amp;lt;/title&amp;gt;&lt;br /&gt;
&amp;lt;/head&amp;gt;&lt;br /&gt;
&amp;lt;body&amp;gt;&lt;br /&gt;
    &amp;lt;form id=&amp;quot;form1&amp;quot; runat=&amp;quot;server&amp;quot;&amp;gt;&lt;br /&gt;
    &amp;lt;div&amp;gt;&lt;br /&gt;
        &amp;lt;asp:GridView ID=&amp;quot;GridView1&amp;quot; runat=&amp;quot;server&amp;quot; Height=&amp;quot;400px&amp;quot; Width=&amp;quot;400px&amp;quot;&amp;gt;&lt;br /&gt;
        &amp;lt;/asp:GridView&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
    &amp;lt;/div&amp;gt;&lt;br /&gt;
    &amp;lt;/form&amp;gt;&lt;br /&gt;
&amp;lt;/body&amp;gt;&lt;br /&gt;
&amp;lt;/html&amp;gt;&lt;br /&gt;
File: Default.aspx.vb&lt;br /&gt;
Imports System.Data&lt;br /&gt;
Imports System.Configuration&lt;br /&gt;
Imports System.Data.SqlClient&lt;br /&gt;
Partial Class _Default&lt;br /&gt;
    Inherits System.Web.UI.Page&lt;br /&gt;
    Protected Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load&lt;br /&gt;
        Response.Write(&amp;quot;Page created: &amp;quot; + DateTime.Now.ToLongTimeString())&lt;br /&gt;
        Dim connStr As String = ConfigurationManager.ConnectionStrings(&amp;quot;AppConnectionString1&amp;quot;).ConnectionString&lt;br /&gt;
        SqlDependency.Start(connStr)&lt;br /&gt;
        Dim connection As New SqlConnection(connStr)&lt;br /&gt;
        Dim command As New SqlCommand(&amp;quot;Select * FROM Customers&amp;quot;, connection)&lt;br /&gt;
        Dim depends As New SqlCacheDependency(command)&lt;br /&gt;
        connection.Open()&lt;br /&gt;
        GridView1.DataSource = command.ExecuteReader()&lt;br /&gt;
        GridView1.DataBind()&lt;br /&gt;
        connection.Close()&lt;br /&gt;
        Response.AddCacheDependency(depends)&lt;br /&gt;
    End Sub&lt;br /&gt;
End Class&lt;br /&gt;
&lt;br /&gt;
File: Web.config&lt;br /&gt;
&amp;lt;?xml version=&amp;quot;1.0&amp;quot;?&amp;gt;&lt;br /&gt;
&amp;lt;configuration&amp;gt;&lt;br /&gt;
  &amp;lt;appSettings/&amp;gt;&lt;br /&gt;
  &amp;lt;connectionStrings&amp;gt;&lt;br /&gt;
    &amp;lt;add name=&amp;quot;AppConnectionString1&amp;quot; connectionString=&amp;quot;Data Source=.\SQLEXPRESS;User ID=wrox;Password=wrox1*c;Database=Northwind;Persist Security Info=False&amp;quot; providerName=&amp;quot;System.Data.SqlClient&amp;quot;/&amp;gt;&lt;br /&gt;
  &amp;lt;/connectionStrings&amp;gt;&lt;br /&gt;
  &amp;lt;system.web&amp;gt;&lt;br /&gt;
    &amp;lt;caching&amp;gt;&lt;br /&gt;
      &amp;lt;sqlCacheDependency enabled=&amp;quot;true&amp;quot;&amp;gt;&lt;br /&gt;
        &amp;lt;databases&amp;gt;&lt;br /&gt;
          &amp;lt;add name=&amp;quot;Northwind&amp;quot; connectionStringName=&amp;quot;AppConnectionString1&amp;quot; pollTime=&amp;quot;500&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;/databases&amp;gt;&lt;br /&gt;
      &amp;lt;/sqlCacheDependency&amp;gt;&lt;br /&gt;
    &amp;lt;/caching&amp;gt;&lt;br /&gt;
    &amp;lt;compilation debug=&amp;quot;true&amp;quot; strict=&amp;quot;false&amp;quot; explicit=&amp;quot;true&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;pages&amp;gt;&lt;br /&gt;
      &amp;lt;namespaces&amp;gt;&lt;br /&gt;
        &amp;lt;clear/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Collections&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Collections.Specialized&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Configuration&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Text&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Text.RegularExpressions&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web.Caching&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web.SessionState&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web.Security&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web.Profile&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web.UI&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web.UI.WebControls&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web.UI.WebControls.WebParts&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web.UI.HtmlControls&amp;quot;/&amp;gt;&lt;br /&gt;
      &amp;lt;/namespaces&amp;gt;&lt;br /&gt;
    &amp;lt;/pages&amp;gt;&lt;br /&gt;
    &amp;lt;authentication mode=&amp;quot;Windows&amp;quot;/&amp;gt;&lt;br /&gt;
  &amp;lt;/system.web&amp;gt;&lt;br /&gt;
&amp;lt;/configuration&amp;gt;&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Using Polling SQL Cache Dependencies with Data Caching==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;%@ Page Language=&amp;quot;C#&amp;quot; Trace=&amp;quot;true&amp;quot; %&amp;gt;&lt;br /&gt;
&amp;lt;%@ Import Namespace=&amp;quot;System.Data&amp;quot; %&amp;gt;&lt;br /&gt;
&amp;lt;%@ Import Namespace=&amp;quot;System.Data.SqlClient&amp;quot; %&amp;gt;&lt;br /&gt;
&amp;lt;%@ Import Namespace=&amp;quot;System.Web.Configuration&amp;quot; %&amp;gt;&lt;br /&gt;
&amp;lt;!DOCTYPE html PUBLIC &amp;quot;-//W3C//DTD XHTML 1.0 Transitional//EN&amp;quot;&lt;br /&gt;
&amp;quot;http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;script runat=&amp;quot;server&amp;quot;&amp;gt;&lt;br /&gt;
    void Page_Load()&lt;br /&gt;
    {&lt;br /&gt;
        DataTable products = (DataTable)Cache[&amp;quot;Products&amp;quot;];&lt;br /&gt;
        if (products == null)&lt;br /&gt;
        {&lt;br /&gt;
            products = GetProductsFromDB();&lt;br /&gt;
            SqlCacheDependency sqlDepend = new SqlCacheDependency(&amp;quot;MyDatabase&amp;quot;, &amp;quot;Products&amp;quot;);&lt;br /&gt;
            Cache.Insert(&amp;quot;Products&amp;quot;, products, sqlDepend);&lt;br /&gt;
        }&lt;br /&gt;
        grdProducts.DataSource = products;&lt;br /&gt;
        grdProducts.DataBind();&lt;br /&gt;
    }&lt;br /&gt;
    private DataTable GetProductsFromDB()&lt;br /&gt;
    {&lt;br /&gt;
        Trace.Warn(&amp;quot;Retrieving data from database&amp;quot;);&lt;br /&gt;
        string conString = WebConfigurationManager.ConnectionStrings [&amp;quot;Products&amp;quot;].ConnectionString;&lt;br /&gt;
        SqlDataAdapter dad = new SqlDataAdapter(&amp;quot;SELECT Title,Director FROM Products&amp;quot;, conString);&lt;br /&gt;
        DataTable products = new DataTable();&lt;br /&gt;
        dad.Fill(products);&lt;br /&gt;
        return products;&lt;br /&gt;
    }&lt;br /&gt;
&amp;lt;/script&amp;gt;&lt;br /&gt;
&amp;lt;html xmlns=&amp;quot;http://www.w3.org/1999/xhtml&amp;quot; &amp;gt;&lt;br /&gt;
&amp;lt;head id=&amp;quot;Head1&amp;quot; runat=&amp;quot;server&amp;quot;&amp;gt;&lt;br /&gt;
    &amp;lt;title&amp;gt;Polling SQL Data Cache&amp;lt;/title&amp;gt;&lt;br /&gt;
&amp;lt;/head&amp;gt;&lt;br /&gt;
&amp;lt;body&amp;gt;&lt;br /&gt;
    &amp;lt;form id=&amp;quot;form1&amp;quot; runat=&amp;quot;server&amp;quot;&amp;gt;&lt;br /&gt;
    &amp;lt;div&amp;gt;&lt;br /&gt;
    &amp;lt;asp:GridView&lt;br /&gt;
        id=&amp;quot;grdProducts&amp;quot;&lt;br /&gt;
        Runat=&amp;quot;server&amp;quot; /&amp;gt;&lt;br /&gt;
    &amp;lt;/div&amp;gt;&lt;br /&gt;
    &amp;lt;/form&amp;gt;&lt;br /&gt;
&amp;lt;/body&amp;gt;&lt;br /&gt;
&amp;lt;/html&amp;gt;&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Using Polling SQL Cache Dependencies with DataSource Caching==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;%@ Page Language=&amp;quot;C#&amp;quot; %&amp;gt;&lt;br /&gt;
&amp;lt;!DOCTYPE html PUBLIC &amp;quot;-//W3C//DTD XHTML 1.0 Transitional//EN&amp;quot;&lt;br /&gt;
&amp;quot;http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;script runat=&amp;quot;server&amp;quot;&amp;gt;&lt;br /&gt;
    protected void srcProducts_Selecting(object sender, SqlDataSourceSelectingEventArgs e)&lt;br /&gt;
    {&lt;br /&gt;
        lblMessage.Text = &amp;quot;Retrieving data from database&amp;quot;;&lt;br /&gt;
    }&lt;br /&gt;
&amp;lt;/script&amp;gt;&lt;br /&gt;
&amp;lt;html xmlns=&amp;quot;http://www.w3.org/1999/xhtml&amp;quot; &amp;gt;&lt;br /&gt;
&amp;lt;head id=&amp;quot;Head1&amp;quot; runat=&amp;quot;server&amp;quot;&amp;gt;&lt;br /&gt;
    &amp;lt;title&amp;gt;Polling SQL DataSource Cache&amp;lt;/title&amp;gt;&lt;br /&gt;
&amp;lt;/head&amp;gt;&lt;br /&gt;
&amp;lt;body&amp;gt;&lt;br /&gt;
    &amp;lt;form id=&amp;quot;form1&amp;quot; runat=&amp;quot;server&amp;quot;&amp;gt;&lt;br /&gt;
    &amp;lt;div&amp;gt;&lt;br /&gt;
    &amp;lt;asp:Label&lt;br /&gt;
        id=&amp;quot;lblMessage&amp;quot;&lt;br /&gt;
        EnableViewState=&amp;quot;false&amp;quot;&lt;br /&gt;
        Runat=&amp;quot;server&amp;quot; /&amp;gt;&lt;br /&gt;
    &amp;lt;hr /&amp;gt;&lt;br /&gt;
    &amp;lt;asp:GridView&lt;br /&gt;
        id=&amp;quot;grdProducts&amp;quot;&lt;br /&gt;
        DataSourceID=&amp;quot;srcProducts&amp;quot;&lt;br /&gt;
        Runat=&amp;quot;server&amp;quot; /&amp;gt;&lt;br /&gt;
    &amp;lt;asp:SqlDataSource&lt;br /&gt;
        id=&amp;quot;srcProducts&amp;quot;&lt;br /&gt;
        ConnectionString=&amp;quot;&amp;lt;%$ ConnectionStrings:Products %&amp;gt;&amp;quot;&lt;br /&gt;
        SelectCommand=&amp;quot;SELECT Title, Director FROM Products&amp;quot;&lt;br /&gt;
        EnableCaching=&amp;quot;true&amp;quot;&lt;br /&gt;
        SqlCacheDependency=&amp;quot;MyDatabase:Products&amp;quot;&lt;br /&gt;
        OnSelecting=&amp;quot;srcProducts_Selecting&amp;quot;&lt;br /&gt;
        Runat=&amp;quot;server&amp;quot; /&amp;gt;&lt;br /&gt;
    &amp;lt;/div&amp;gt;&lt;br /&gt;
    &amp;lt;/form&amp;gt;&lt;br /&gt;
&amp;lt;/body&amp;gt;&lt;br /&gt;
&amp;lt;/html&amp;gt;&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Using Polling SQL Cache Dependencies with Page Output Caching==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;%@ Page Language=&amp;quot;C#&amp;quot; %&amp;gt;&lt;br /&gt;
&amp;lt;%@ OutputCache Duration=&amp;quot;9999&amp;quot; VaryByParam=&amp;quot;none&amp;quot;&lt;br /&gt;
  SqlDependency=&amp;quot;MyDatabase:Products&amp;quot; %&amp;gt;&lt;br /&gt;
&amp;lt;!DOCTYPE html PUBLIC &amp;quot;-//W3C//DTD XHTML 1.0 Transitional//EN&amp;quot;&lt;br /&gt;
  &amp;quot;http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;html xmlns=&amp;quot;http://www.w3.org/1999/xhtml&amp;quot; &amp;gt;&lt;br /&gt;
&amp;lt;head id=&amp;quot;Head1&amp;quot; runat=&amp;quot;server&amp;quot;&amp;gt;&lt;br /&gt;
    &amp;lt;title&amp;gt;Polling SQL Output Cache&amp;lt;/title&amp;gt;&lt;br /&gt;
&amp;lt;/head&amp;gt;&lt;br /&gt;
&amp;lt;body&amp;gt;&lt;br /&gt;
    &amp;lt;form id=&amp;quot;form1&amp;quot; runat=&amp;quot;server&amp;quot;&amp;gt;&lt;br /&gt;
    &amp;lt;div&amp;gt;&lt;br /&gt;
    &amp;lt;%= DateTime.Now.ToString(&amp;quot;T&amp;quot;) %&amp;gt;&lt;br /&gt;
    &amp;lt;hr /&amp;gt;&lt;br /&gt;
    &amp;lt;asp:GridView&lt;br /&gt;
        id=&amp;quot;grdProducts&amp;quot;&lt;br /&gt;
        DataSourceID=&amp;quot;srcProducts&amp;quot;&lt;br /&gt;
        Runat=&amp;quot;server&amp;quot; /&amp;gt;&lt;br /&gt;
    &amp;lt;asp:SqlDataSource&lt;br /&gt;
        id=&amp;quot;srcProducts&amp;quot;&lt;br /&gt;
        ConnectionString=&amp;quot;&amp;lt;%$ ConnectionStrings:Products %&amp;gt;&amp;quot;&lt;br /&gt;
        SelectCommand=&amp;quot;SELECT Title, Director FROM Products&amp;quot;&lt;br /&gt;
        Runat=&amp;quot;server&amp;quot; /&amp;gt;&lt;br /&gt;
    &amp;lt;/div&amp;gt;&lt;br /&gt;
    &amp;lt;/form&amp;gt;&lt;br /&gt;
&amp;lt;/body&amp;gt;&lt;br /&gt;
&amp;lt;/html&amp;gt;&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Using SQL Cache Dependencies==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt;&lt;br /&gt;
File: Web.Config&lt;br /&gt;
&amp;lt;configuration&amp;gt;&lt;br /&gt;
  &amp;lt;connectionStrings&amp;gt;&lt;br /&gt;
    &amp;lt;add name=&amp;quot;Products&amp;quot; connectionString=&amp;quot;Data Source=.\SQLEXPRESS;&lt;br /&gt;
      AttachDbFilename=|DataDirectory|MyDatabase.mdf;Integrated Security=True;&lt;br /&gt;
User Instance=True&amp;quot; /&amp;gt;&lt;br /&gt;
  &amp;lt;/connectionStrings&amp;gt;&lt;br /&gt;
  &amp;lt;system.web&amp;gt;&lt;br /&gt;
    &amp;lt;caching&amp;gt;&lt;br /&gt;
      &amp;lt;sqlCacheDependency enabled=&amp;quot;true&amp;quot; pollTime=&amp;quot;5000&amp;quot;&amp;gt;&lt;br /&gt;
        &amp;lt;databases&amp;gt;&lt;br /&gt;
          &amp;lt;add&lt;br /&gt;
            name=&amp;quot;MyDatabase&amp;quot;&lt;br /&gt;
            connectionStringName=&amp;quot;Products&amp;quot; /&amp;gt;&lt;br /&gt;
        &amp;lt;/databases&amp;gt;&lt;br /&gt;
      &amp;lt;/sqlCacheDependency&amp;gt;&lt;br /&gt;
    &amp;lt;/caching&amp;gt;&lt;br /&gt;
  &amp;lt;/system.web&amp;gt;&lt;br /&gt;
&amp;lt;/configuration&amp;gt;&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Using the Cache object with the SqlDependency object (C#)==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;%@ Page Language=&amp;quot;C#&amp;quot; %&amp;gt;&lt;br /&gt;
&amp;lt;%@ Import Namespace=&amp;quot;System.Data&amp;quot; %&amp;gt;&lt;br /&gt;
&amp;lt;%@ Import Namespace=&amp;quot;System.Data.SqlClient&amp;quot; %&amp;gt;&lt;br /&gt;
&amp;lt;script runat=&amp;quot;server&amp;quot;&amp;gt;&lt;br /&gt;
    protected void Page_Load(object sender, System.EventArgs e)&lt;br /&gt;
    {&lt;br /&gt;
       DataSet myCustomers;&lt;br /&gt;
       myCustomers = (DataSet)Cache[&amp;quot;firmCustomers&amp;quot;];&lt;br /&gt;
       if (myCustomers == null)&lt;br /&gt;
       {&lt;br /&gt;
          SqlConnection conn = new SqlConnection( ConfigurationManager.ConnectionStrings[&amp;quot;AppConnectionString1&amp;quot;].ConnectionString);&lt;br /&gt;
          SqlDataAdapter da = new SqlDataAdapter(&amp;quot;Select * from Customers&amp;quot;, conn);&lt;br /&gt;
          &lt;br /&gt;
          myCustomers = new DataSet();&lt;br /&gt;
          da.Fill(myCustomers);&lt;br /&gt;
          SqlCacheDependency myDependency = new SqlCacheDependency(&amp;quot;Northwind&amp;quot;, &amp;quot;Customers&amp;quot;);&lt;br /&gt;
          Cache.Insert(&amp;quot;firmCustomers&amp;quot;, myCustomers, myDependency);&lt;br /&gt;
          Label1.Text = &amp;quot;Produced from database.&amp;quot;; &lt;br /&gt;
        }&lt;br /&gt;
        else&lt;br /&gt;
        {&lt;br /&gt;
          Label1.Text = &amp;quot;Produced from Cache object.&amp;quot;;&lt;br /&gt;
        }&lt;br /&gt;
        GridView1.DataSource = myCustomers;&lt;br /&gt;
        GridView1.DataBind();&lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/script&amp;gt;&lt;br /&gt;
&amp;lt;html xmlns=&amp;quot;http://www.w3.org/1999/xhtml&amp;quot; &amp;gt;&lt;br /&gt;
&amp;lt;head id=&amp;quot;Head1&amp;quot; runat=&amp;quot;server&amp;quot;&amp;gt;&lt;br /&gt;
    &amp;lt;title&amp;gt;Sql Cache Invalidation&amp;lt;/title&amp;gt;&lt;br /&gt;
&amp;lt;/head&amp;gt;&lt;br /&gt;
&amp;lt;body&amp;gt;&lt;br /&gt;
    &amp;lt;form id=&amp;quot;form1&amp;quot; runat=&amp;quot;server&amp;quot;&amp;gt;&lt;br /&gt;
        &amp;lt;asp:Label ID=&amp;quot;Label1&amp;quot; Runat=&amp;quot;server&amp;quot;&amp;gt;&amp;lt;/asp:Label&amp;gt;&amp;lt;br /&amp;gt;&lt;br /&gt;
        &amp;lt;br /&amp;gt;&lt;br /&gt;
        &amp;lt;asp:GridView ID=&amp;quot;GridView1&amp;quot; Runat=&amp;quot;server&amp;quot;&amp;gt;&amp;lt;/asp:GridView&amp;gt;&lt;br /&gt;
    &amp;lt;/form&amp;gt;&lt;br /&gt;
&amp;lt;/body&amp;gt;&lt;br /&gt;
&amp;lt;/html&amp;gt;&lt;br /&gt;
File: Web.config&lt;br /&gt;
&amp;lt;?xml version=&amp;quot;1.0&amp;quot;?&amp;gt;&lt;br /&gt;
&amp;lt;configuration&amp;gt;&lt;br /&gt;
  &amp;lt;appSettings/&amp;gt;&lt;br /&gt;
  &amp;lt;connectionStrings&amp;gt;&lt;br /&gt;
    &amp;lt;add name=&amp;quot;AppConnectionString1&amp;quot; connectionString=&amp;quot;Data Source=.\SQLEXPRESS;User ID=wrox;Password=wrox1*c;Database=Northwind;Persist Security Info=False&amp;quot; providerName=&amp;quot;System.Data.SqlClient&amp;quot;/&amp;gt;&lt;br /&gt;
  &amp;lt;/connectionStrings&amp;gt;&lt;br /&gt;
  &amp;lt;system.web&amp;gt;&lt;br /&gt;
    &amp;lt;caching&amp;gt;&lt;br /&gt;
      &amp;lt;sqlCacheDependency enabled=&amp;quot;true&amp;quot;&amp;gt;&lt;br /&gt;
        &amp;lt;databases&amp;gt;&lt;br /&gt;
          &amp;lt;add name=&amp;quot;Northwind&amp;quot; connectionStringName=&amp;quot;AppConnectionString1&amp;quot; pollTime=&amp;quot;500&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;/databases&amp;gt;&lt;br /&gt;
      &amp;lt;/sqlCacheDependency&amp;gt;&lt;br /&gt;
    &amp;lt;/caching&amp;gt;&lt;br /&gt;
    &amp;lt;compilation debug=&amp;quot;true&amp;quot; strict=&amp;quot;false&amp;quot; explicit=&amp;quot;true&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;pages&amp;gt;&lt;br /&gt;
      &amp;lt;namespaces&amp;gt;&lt;br /&gt;
        &amp;lt;clear/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Collections&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Collections.Specialized&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Configuration&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Text&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Text.RegularExpressions&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web.Caching&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web.SessionState&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web.Security&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web.Profile&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web.UI&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web.UI.WebControls&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web.UI.WebControls.WebParts&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web.UI.HtmlControls&amp;quot;/&amp;gt;&lt;br /&gt;
      &amp;lt;/namespaces&amp;gt;&lt;br /&gt;
    &amp;lt;/pages&amp;gt;&lt;br /&gt;
    &amp;lt;authentication mode=&amp;quot;Windows&amp;quot;/&amp;gt;&lt;br /&gt;
  &amp;lt;/system.web&amp;gt;&lt;br /&gt;
&amp;lt;/configuration&amp;gt;&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Using the Cache object with the SqlDependency object (VB)==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;%@ Page Language=&amp;quot;VB&amp;quot; %&amp;gt;&lt;br /&gt;
&amp;lt;%@ Import Namespace=&amp;quot;System.Data&amp;quot;%&amp;gt;&lt;br /&gt;
&amp;lt;%@ Import Namespace=&amp;quot;System.Data.SqlClient&amp;quot;%&amp;gt;&lt;br /&gt;
&amp;lt;script runat=&amp;quot;server&amp;quot;&amp;gt;&lt;br /&gt;
    Protected Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs)&lt;br /&gt;
        Dim myCustomers As DataSet&lt;br /&gt;
        myCustomers = CType(Cache(&amp;quot;firmCustomers&amp;quot;), DataSet)&lt;br /&gt;
        If myCustomers Is Nothing Then&lt;br /&gt;
           Dim conn As SqlConnection = New SqlConnection( ConfigurationManager.ConnectionStrings(&amp;quot;AppConnectionString1&amp;quot;).ConnectionString)&lt;br /&gt;
           Dim da As SqlDataAdapter = New SqlDataAdapter(&amp;quot;Select * From Customers&amp;quot;, conn)&lt;br /&gt;
           myCustomers = New DataSet&lt;br /&gt;
           da.Fill(myCustomers)&lt;br /&gt;
           Dim myDependency As SqlCacheDependency = New SqlCacheDependency(&amp;quot;Northwind&amp;quot;, &amp;quot;Customers&amp;quot;)&lt;br /&gt;
           Cache.Insert(&amp;quot;firmCustomers&amp;quot;, myCustomers, myDependency)&lt;br /&gt;
           Label1.Text = &amp;quot;Produced from database.&amp;quot;&lt;br /&gt;
        Else&lt;br /&gt;
           Label1.Text = &amp;quot;Produced from Cache object.&amp;quot;      &lt;br /&gt;
        End If&lt;br /&gt;
        GridView1.DataSource = myCustomers&lt;br /&gt;
        GridView1.DataBind()&lt;br /&gt;
    End Sub&lt;br /&gt;
&amp;lt;/script&amp;gt;&lt;br /&gt;
&amp;lt;html xmlns=&amp;quot;http://www.w3.org/1999/xhtml&amp;quot; &amp;gt;&lt;br /&gt;
&amp;lt;head id=&amp;quot;Head1&amp;quot; runat=&amp;quot;server&amp;quot;&amp;gt;&lt;br /&gt;
    &amp;lt;title&amp;gt;Sql Cache Invalidation&amp;lt;/title&amp;gt;&lt;br /&gt;
&amp;lt;/head&amp;gt;&lt;br /&gt;
&amp;lt;body&amp;gt;&lt;br /&gt;
    &amp;lt;form id=&amp;quot;form1&amp;quot; runat=&amp;quot;server&amp;quot;&amp;gt;&lt;br /&gt;
        &amp;lt;asp:Label ID=&amp;quot;Label1&amp;quot; Runat=&amp;quot;server&amp;quot;&amp;gt;&amp;lt;/asp:Label&amp;gt;&amp;lt;br /&amp;gt;&lt;br /&gt;
        &amp;lt;br /&amp;gt;&lt;br /&gt;
        &amp;lt;asp:GridView ID=&amp;quot;GridView1&amp;quot; Runat=&amp;quot;server&amp;quot;&amp;gt;&amp;lt;/asp:GridView&amp;gt;&lt;br /&gt;
    &amp;lt;/form&amp;gt;&lt;br /&gt;
&amp;lt;/body&amp;gt;&lt;br /&gt;
&amp;lt;/html&amp;gt;&lt;br /&gt;
File: Web.config&lt;br /&gt;
&amp;lt;?xml version=&amp;quot;1.0&amp;quot;?&amp;gt;&lt;br /&gt;
&amp;lt;configuration&amp;gt;&lt;br /&gt;
  &amp;lt;appSettings/&amp;gt;&lt;br /&gt;
  &amp;lt;connectionStrings&amp;gt;&lt;br /&gt;
    &amp;lt;add name=&amp;quot;AppConnectionString1&amp;quot; connectionString=&amp;quot;Data Source=.\SQLEXPRESS;User ID=wrox;Password=wrox1*c;Database=Northwind;Persist Security Info=False&amp;quot; providerName=&amp;quot;System.Data.SqlClient&amp;quot;/&amp;gt;&lt;br /&gt;
  &amp;lt;/connectionStrings&amp;gt;&lt;br /&gt;
  &amp;lt;system.web&amp;gt;&lt;br /&gt;
    &amp;lt;caching&amp;gt;&lt;br /&gt;
      &amp;lt;sqlCacheDependency enabled=&amp;quot;true&amp;quot;&amp;gt;&lt;br /&gt;
        &amp;lt;databases&amp;gt;&lt;br /&gt;
          &amp;lt;add name=&amp;quot;Northwind&amp;quot; connectionStringName=&amp;quot;AppConnectionString1&amp;quot; pollTime=&amp;quot;500&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;/databases&amp;gt;&lt;br /&gt;
      &amp;lt;/sqlCacheDependency&amp;gt;&lt;br /&gt;
    &amp;lt;/caching&amp;gt;&lt;br /&gt;
    &amp;lt;compilation debug=&amp;quot;true&amp;quot; strict=&amp;quot;false&amp;quot; explicit=&amp;quot;true&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;pages&amp;gt;&lt;br /&gt;
      &amp;lt;namespaces&amp;gt;&lt;br /&gt;
        &amp;lt;clear/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Collections&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Collections.Specialized&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Configuration&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Text&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Text.RegularExpressions&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web.Caching&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web.SessionState&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web.Security&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web.Profile&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web.UI&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web.UI.WebControls&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web.UI.WebControls.WebParts&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;add namespace=&amp;quot;System.Web.UI.HtmlControls&amp;quot;/&amp;gt;&lt;br /&gt;
      &amp;lt;/namespaces&amp;gt;&lt;br /&gt;
    &amp;lt;/pages&amp;gt;&lt;br /&gt;
    &amp;lt;authentication mode=&amp;quot;Windows&amp;quot;/&amp;gt;&lt;br /&gt;
  &amp;lt;/system.web&amp;gt;&lt;br /&gt;
&amp;lt;/configuration&amp;gt;&amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>