Welcome to Scribd, the world's digital library. Read, publish, and share books and documents. See more
Standard view
Full view
of .
Look up keyword
Like this
0 of .
Results for:
No results containing your search query
P. 1
Caching ASP.Net

Caching ASP.Net

Ratings: (0)|Views: 137|Likes:
Published by api-3757055

More info:

Published by: api-3757055 on Oct 15, 2008
Copyright:Attribution Non-commercial


Read on Scribd mobile: iPhone, iPad and Android.
download as DOC, PDF, TXT or read online from Scribd
See more
See less





If you're using typically static data with your ASP.NET applications - such as that from a database server like Microsoft SQL Server - you should take a look at caching your data. Previously, this was not an easy thing to do, but the caching in .NET makes caching your data and objects a trivial task. This tutorial will cover basic caching and scenarios where caching would be good to use.

Using the Cache Property

In ASP.NET, every page you write extends the System.Web.UI.Page class, which
contains a member called Cache. You use the Cache property as you would any other
IEnumerable, which gives you methods and properties to get, set, and enumerate through
members. We will be looking at getting and setting items in the cache. In the simplest
example, you can retrieve any object from the cache like so:

Object obj = (Object)Cache["key"];

What this does is look in the Cache for an item with the key"key". If such an item exists,
the object is returned. While we don't need to cast the returned object to Object, this is
just an example of how you must cast the return to the class type you want returned. If
the item is not found, null is returned, so you will need to do some checking:

Object obj = (Object)Cache["key"];
if (obj == null) {
// Generate a new object and insert it into the cache
}// Use your object
You can also assign object to the cache like the following code example, but using
Cache.Inset() is a much better means as you'll see later:
Cache["key"] = obj;

Now let's look at a serious example. In the example below, we will define a function that
binds data to a control, such as a ASP.NET DataGrid control. We will look at data binding
in a little more depth later. For this example, we will use a System.Data.DataSet object.
<%@ Page Language="C#" %>
<%@ Import Namespace="System.Data"

<script runat="server">
private string _filename = "mydata.xml";

private void Page_Load(Object src, EventArgs args) {
DataSet ds = (DataSet)Cache["mydata"];
if (ds == null) {


Cache.Insert("mydata", ds,
new CacheDependency(Server.MapPath(_filename)),
DateTime.Now.AddHours(12), NoSlidingExpiration);

myDataGrid.DataSource = ds;
}We'll break down the above example. The first part we've already discussed, where we

get the object from the cache. If the object is null (i.e., doesn't exist in the cache), we
need to create the object. The first line after checking if our DataSet object is null loads
an XML file called a DiffGram, which is a serialized DataSet object. We'll talk about this
later. Essentially, the DataSet object (hereforth, "ds") is created from serialized XML,
which you can event type by hand. We call Server.MapPath() because the file as we know
it is virtual. ds.ReadXml needs the absolute path and filename to load it.
Server.MapPath() figures out what the absolute path of a virtual filename (such as your
web pages) and returns the absolute path.

The next statement inserts the newly created "ds" into the cache. Again, the statement is:

Cache.Insert("mydata", ds,
new CacheDependency(Server.MapPath(_filename)),
DateTime.Now.AddHours(12), NoSlidingExpiration);

1. The first parameter is the key used to identify our cache item.

2. The second parameter is the object we want to cache. In this example, we are caching the DataSet object "ds". This can be any object, however, including strings, numbers, controls, etc.

3. The third parameter creates a dependency on an object. If this object changes, the cached object is marked as expired and your application will regenerate next time, returning null as your object reference. In fact, the object is expired. You can also pass null in this parameter to signify that you don't want any dependencies.

4. The fourth parameter is the absolute expiration period your object is valid. Here,
we use DateTime.Now (which uses "now's" time) and add 12 hours to it. This
means the object will automatically expire in 12 hours. You could also use
NoAbsoluteExpiration which means the object will never expire until the
dependent object changes. We use an absolute expiration here to make sure we
have somewhat recent data in case the CacheDependency doesn't expire the data
for some reason. (As if Microsoft software doesn't have bugs!)

5. The fifth and final parameter is a sliding expiration. This means that if the object
is access, the absolute expiration time is essentially pushed back to however many
minutes, hours, etc. you specify here. This is an object of type TimeSpan. Here,
we want our object expired after 12 hours even if the object is accessed before

After all this, we can finally bind our object to a data-driven control, such as the
ASP.NET DataGrid control. While the full use of the control is out of the scope of this
tutorial, I will cover the usage in brief detail.

The DataGrid control is a data-driven control meaning that on the server, the control will
use data and will then render the HTML onto the page for the client to see in their
browser. We will define a basic DataGrid control customizing only a few parameters:


<asp:DataGrid id="myDataGrid" runat="server"
<HeaderStyle Font-Bold="true"/>

Please note: this example assumes you already have your other HTML tags setup and
that the DataGrid is the only control in the BODY, which it doesn't have to be.

Above, we define a Web server control of type DataGrid, which is a data-driven control
that renders a table on the page. By setting AutoGenerateColumns to true (which is
default anyway), we specify that the DataGrid control will automatically generate headers
and columns based on your data in the order of the columns in your DataSet. We also
setup default paging and a few items styles, while making the Header column text bold.

In the example Page_Load() event handler, we did a little data binding like so:
myDataGrid.DataSource = ds;

These two lines associate the DataSource property of the DataGrid with our DataSet
object "ds" and then binds the data with DataBind(). If you do not call DataBind(), you
will find that nothing is rendered on your page. The DataSource property can point at
other types of object, like ArrayList(), DataView() and many others. Consult your .NET
SDK Documentation for more details.

Why would you use this tutorial to build your next data-driven ASP.NET page? There are
several examples, but I will discuss one here.

Lets say that you've developed a page or site that generates a table of contents on ever
page. You also have a SQL Server storing this data because the table of contents changes
from time to time. Instead of making calls across the network to the SQL Server (even
cached data on SQL Server requires a few calls back and forth), you could use the
caching example above.

There are two ways primary ways of handling this:

Activity (15)

You've already reviewed this. Edit your review.
1 hundred reads
alexandergsam liked this
Aashish Kumar liked this
Datazone liked this
maneniin2042 liked this
satya1401 liked this
sridhar00912 liked this
sridhar00912 liked this
san30982 liked this

You're Reading a Free Preview

/*********** DO NOT ALTER ANYTHING BELOW THIS LINE ! ************/ var s_code=s.t();if(s_code)document.write(s_code)//-->