When you think ASP, think...
Recent Articles
All Articles
ASP.NET Articles [1.x] [2.0]
ASPFAQs.com
Message Board
Related Web Technologies
User Tips!
Coding Tips
Search

Sections:
Book Reviews
Sample Chapters
Commonly Asked Message Board Questions
Headlines from ASPWire.com
JavaScript Tutorials
MSDN Communities Hub
Official Docs
Security
Stump the SQL Guru!
Web Hosts
XML Info
Information:
Advertise
Feedback
Author an Article
Technology Jobs

















internet.com
IT
Developer
Internet News
Small Business
Personal Technology
International

Search internet.com
Advertise
Corporate Info
Newsletters
Tech Jobs
E-mail Offers
ASP ASP.NET ASP FAQs Message Board Feedback ASP Jobs
Print this page.

Windows Systems Administrator
Jupitermedia
US-CT-Darien

Justtechjobs.com Post A Job | Post A Resume

Published: Sunday, November 08, 1998

WebDaily: Your daily source for Web Technology Tips and Tricks!


*****************************************************************
Optimizing ASP Performance
*****************************************************************

* This article discusses programming techniques for developing optimized Active Server Pages applications.

Last article I discussed connection pooling, and how it can be used to increase the efficiency with which your ASP applications connect to the databases you are using. And if you'll recall, a few articles ago I wrote about optimizing your ASP code for maintainability and reliability. This article I intend on discussing techniques which you can easily employ to optimize your ASP code's performance.

The first step to not only increasing your ASP performance, but to also making your ASP more user friendly, is to abandon the use of ALL Session variables (unless they are absolutely needed). Session variables are maintained by cookies on the client side; so if the web surfer has cookies turned off in his browser, the Session variables won't work! Also, Session variables have a lengthy lifetime. An instance of each session variable is instantiated when a new user hits the webserver. From the time this user makes his last request, there is still a good 20 minutes until the Session variable instance is deleted. (The length can be set by the Session.Timeout property or through the registry.)

So, if you are storing large numbers of complex objects in your Session variables, then you are asking for decreased performance. Some things, you may argue, MUST be put in the Session. If this is the case, at least try your hardest NOT to put large and complex objects in the Session, such as large, dynamic arrays, ADO Objects, or instances of business objects.

Another useful tip to increase your database performance is to use stored procedures as opposed to dynamically created queries on the ASP level. As I mentioned in a previoous article, the desired Web Application architecture consists of three tiers. The top tier is your ASP code, the middle tier are your business objects, and your bottom tier is the SQL Server backend. The desired approach consists of ASP calling business object methods, which in turn call stored procedures in the SQL database. This, as I explained earlier, is desired because maintenance is extraordinarily easier when you add levels of abstraction. Another plus to using SQL stored procedures is that once the procedure is executed once, an execution plan is cached in SQL's memory, and subsequent runs execute quicker.

Let's say you are writing a page which does nothing but inputs a row into your Employee table. It receives information from another page based on a form. Let's look at some code:

<%
'Establish connection
Dim Name, Salary, strSQL
Name = Request("txtName")
Salary = Request("Salary")

strSQL = "INSERT Employee (Name,Salary) VALUES('" & _
Name & "'," & Salary & ")"
Conn.Execute(strSQL)


Response.Redirect("SomePage.htm")
%>

We can use stored procedures instead to optimize this code. To create a stored procedure, you just need to go into SQL Server, expand the database you want to create a stored procedure. You'll see a "Stored Procedures" folder. Right click on it, and select "New Stored Procedure." Now, just type in your query and hit save!

Here is what the procedure will look like:

  CREATE PROCEDURE sp_InsertEmployee (@Name varchar(100), @Salary money)
  AS

    INSERT Employee (Name,Salary)
    VALUES(@Name,@Salary)

  GO

In your ASP, you can call the procedure in two ways. The first way is to do something like:

<%
'Make connection to database
Conn.Execute("sp_InsertEmployee '" & Request("Name") & _
"'," & Request("Salary"))

...
%>

The other way is to use the Parameters collection inherent in ADO. I will save this dicussion for a future WebDaily article.

Happy Programming!


*****************************************************************
*****************************************************************
To subscribe to WebDaily, point your browser to:
http://www.4GuysFromRolla.com/webtech/webdaily
*****************************************************************
*****************************************************************


Windows Internet Technology | ASP.NET [1.x] [2.0] | ASPMessageboard.com | ASPFAQs.com | Advertise | Feedback | Author an Article



JupiterOnlineMedia

internet.comearthweb.comDevx.commediabistro.comGraphics.com

Search:

Jupitermedia Corporation has two divisions: Jupiterimages and JupiterOnlineMedia

Jupitermedia Corporate Info


Legal Notices, Licensing, Reprints, & Permissions, Privacy Policy.

Advertise | Newsletters | Tech Jobs | Shopping | E-mail Offers

Solutions
Whitepapers and eBooks
Microsoft Article: Will Hyper-V Make VMware This Decade's Netscape?
Microsoft Article: 7.0, Microsoft's Lucky Version?
Microsoft Article: Hyper-V--The Killer Feature in Windows Server 2008
Avaya Article: How to Feed Data into the Avaya Event Processor
Microsoft Article: Install What You Need with Windows Server 2008
HP eBook: Putting the Green into IT
Whitepaper: HP Integrated Citrix XenServer for HP ProLiant Servers
Intel Go Parallel Portal: Interview with C++ Guru Herb Sutter, Part 1
Intel Go Parallel Portal: Interview with C++ Guru Herb Sutter, Part 2--The Future of Concurrency
Avaya Article: Setting Up a SIP A/S Development Environment
IBM Article: How Cool Is Your Data Center?
Microsoft Article: Managing Virtual Machines with Microsoft System Center
HP eBook: Storage Networking , Part 1
Microsoft Article: Solving Data Center Complexity with Microsoft System Center Configuration Manager 2007
MORE WHITEPAPERS, EBOOKS, AND ARTICLES
Webcasts
Intel Video: Are Multi-core Processors Here to Stay?
On-Demand Webcast: Five Virtualization Trends to Watch
HP Video: Page Cost Calculator
Intel Video: APIs for Parallel Programming
HP Webcast: Storage Is Changing Fast - Be Ready or Be Left Behind
Microsoft Silverlight Video: Creating Fading Controls with Expression Design and Expression Blend 2
MORE WEBCASTS, PODCASTS, AND VIDEOS
Downloads and eKits
Sun Download: Solaris 8 Migration Assistant
Sybase Download: SQL Anywhere Developer Edition
Red Gate Download: SQL Backup Pro and free DBA Best Practices eBook
Red Gate Download: SQL Compare Pro 6
Iron Speed Designer Application Generator
MORE DOWNLOADS, EKITS, AND FREE TRIALS
Tutorials and Demos
How-to-Article: Preparing for Hyper-Threading Technology and Dual Core Technology
eTouch PDF: Conquering the Tyranny of E-Mail and Word Processors
IBM Article: Collaborating in the High-Performance Workplace
HP Demo: StorageWorks EVA4400
Intel Featured Algorhythm: Intel Threading Building Blocks--The Pipeline Class
Microsoft How-to Article: Get Going with Silverlight and Windows Live
MORE TUTORIALS, DEMOS AND STEP-BY-STEP GUIDES