Monday, June 21, 2010

ASP.Net State management


What is State Management?
State management is the process by which you maintain state and page information over multiple requests for the same or different pages.
ASP.NET includes several options that help you preserve data on both a per-page basis and an application-wide basis.

Types of State Management
There are two basic types of State Management:
1.       Client-Based State Management
2.       Server-Based State Management
Client-Based State Management:
Client based state management techniques stores data on the client in various ways. Client based state management techniques are:
A.      View state
B.      Control state
C.      Hidden fields
D.      Cookies
E.       Query strings

View state:
The view state represents the state of the page when it was last processed on the server. It's used to build a call context and retain values across two successive requests for the same page. By default, the state is persisted on the client using a hidden field added to the page and is restored on the server before the page request is processed.
If the amount of data stored in the ViewState() property exceeds the specified value in the MaxPageStateFieldLength() property, multiple hidden fields are used to store View state data.
                Advantages:     
a)      Server resources not required.
b)      Simple implementation
c)       automatic retention of page and control state
d)      Enhanced security features. The values in view state are hashed, compressed, and encoded for Unicode implementations.

Disadvantages:
a)      Scope is limited to only single page.
b)      Performance. The view state is stored in the page itself, so increase the page size.
c)       Security. The view state is stored in a hidden field on the page. Although view state stores data in a hashed format, it can be tampered with.

Control state:
If you create a custom control that requires view state to work properly, you should use control state to ensure your control work properly though developers disable view state. The ControlState() property allows you to persist property information that is specific to a control and cannot be turned off like the ViewState() property.
     Advantages:     
a)      Server resources not required.
b)      Reliable. Because control state can not be turned off like ViewState.

Disadvantages:
a)      Some programming is required.
Hidden Fields:
A hidden field acts as a repository for any page-specific information that you want to store directly in the page. ASP.NET allows you to store information in a HiddenField control, which renders as a standard HTML hidden field. A hidden field does not render visibly in the browser.
You must submit the page using an HTTP POST command in order for hidden-field values to be available.

                Advantages:     
a)      Server resources not required.
b)      Simple implementation
c)       Widespread support.

Disadvantages:
a)      Potential security risk.
b)      Performance. The hidden fields are stored in the page itself, so increase the page size.
c)       Does not support rich data types to store.
Cookies:
A cookie is a small amount of data that is stored either in a text file on the client file system or in-memory in the client browser session. Browser sends with cookies values with every page request to the same server. Cookies can be temporary or persistent.

Advantages:     
a)      Server resources not required.
b)      Simple implementation
c)       Configurable expiration rules
d)      Data persistent.

Disadvantages:
e)      Size limitation: Most browsers support maximum 4096 bytes cookies.
f)       User configuration refusal: User can disable cookies in their browser.
g)      Security risk: Can be tempered.

Query strings:
A query string is information that is appended to the end of a page URL. Query strings provide a simple but limited way to maintain state information.  Some browsers and client devices impose a 2083 character limit on the length of the URL.
You must submit the page using an HTTP POST command in order for query string values to be available.
Advantages:     
h)      Server resources not required.
i)        Simple implementation
j)        Widespread support.

Disadvantages:
k)      Size limitation: Some browser limits 2083 chars on the length of URLs.
l)        Security risk: Information is visible to the user.

Server-Based State Management:
Server based state management techniques store data in memory on the server.  Server based state management techniques are:
A.      Application state
B.      Session state
C.      Profile Properties

Application state:
Application state provides a method of storing data global to whole application. These data are visible to entire application and shared by all active sessions. That’s why Application state variables are global variables for an ASP.Net application.
Advantages:     
m)    Simple implementation
n)      Application wide scope

Disadvantages:
o)      Application scope in case of Web Garden or Web Firm.
p)      Limited Durability of data.
q)      Requires server memory.

Session state:
Session state provides a method of storing session specific information that is visible only within the session.
Advantages:     
r)       Simple implementation
s)       Session specific events
t)       Data can persists across multiple process

Disadvantages:
u)      Application scope
v)      Limited Durability of data.
w)    Requires server memory.

Sunday, June 13, 2010

T-SQL Dynamic Paged Query Techniques


Here we will see how to write dynamic paged query using Derived Table and CTE.


Simple paging query using Derived Table:

CREATE PROCEDURE [dbo].[HrEmployee_GetPaged]
AS
BEGIN
      SET NOCOUNT ON
SET TRANSACTION ISOLATION LEVEL READ COMMITTED
select * from
( select  row_number() over(order by EmployeeId) as Row,* from HrEmployee ) as e
where e.Row between 21 and 30 
END

Dynamic paging query using Derived Table:

CREATE PROCEDURE [dbo].[HrEmployee_GetPaged]
      @StartRowIndex        int,
      @RowPerPage       int,
      @WhereClause      nvarchar(4000),
      @SortColumn       nvarchar(128),
      @SortOrder        nvarchar(4)
AS
BEGIN
      SET NOCOUNT ON
SET TRANSACTION ISOLATION LEVEL READ COMMITTED

      SET @StartRowIndex = isnull(@StartRowIndex, -1)
      SET @RowPerPage = isnull(@RowPerPage, -1)
      SET @WhereClause = isnull(@WhereClause, '')
      SET @SortColumn = isnull(@SortColumn, '')
      SET @SortOrder = isnull(@SortOrder, '')

DECLARE @SQL nvarchar(4000)

      IF (@WhereClause != '')
      BEGIN
            SET @WhereClause = 'WHERE ' + char(13) + @WhereClause
      END

      IF (@SortColumn != '')
      BEGIN
            SET @SortColumn = 'ORDER BY ' + @SortColumn
            IF (@SortOrder != '')
                  BEGIN
                        SET @SortColumn = @SortColumn + ' ' + @SortOrder
                  END
      END
      SET @SQL = 'SELECT * FROM (SELECT *,
                        ROW_NUMBER() OVER ('+ @SortColumn +')AS Row
                        FROM  [HrEmployee]
                        '+ @WhereClause +'
                        ) as E
                         
                        WHERE E.Row between '+ CONVERT(nvarchar(10), @StartRowIndex) +' And ('+ CONVERT(nvarchar(10), @StartRowIndex+ @RowPerPage-1) +')'
--    print @SQL
EXEC sp_executesql @SQL


END



Simple paging query using CTE:

CREATE PROCEDURE [dbo].[HrEmployee_GetPaged]
AS
BEGIN
      SET NOCOUNT ON
SET TRANSACTION ISOLATION LEVEL READ COMMITTED
WITH e AS (select  row_number() over(order by EmployeeId) as Row,* from HrEmployee )
select * from e where e.Row between 21 and 30
END

Dynamic paging query using CTE:

CREATE PROCEDURE [dbo].[HrEmployee_GetPaged]
      @StartRowIndex        int,
      @RowPerPage       int,
      @WhereClause      nvarchar(4000),
      @SortColumn       nvarchar(128),
      @SortOrder        nvarchar(4)
AS
BEGIN
      SET NOCOUNT ON
SET TRANSACTION ISOLATION LEVEL READ COMMITTED

      SET @StartRowIndex = isnull(@StartRowIndex, -1)
      SET @RowPerPage = isnull(@RowPerPage, -1)
      SET @WhereClause = isnull(@WhereClause, '')
      SET @SortColumn = isnull(@SortColumn, '')
      SET @SortOrder = isnull(@SortOrder, '')

DECLARE @SQL nvarchar(4000)

      IF (@WhereClause != '')
      BEGIN
            SET @WhereClause = 'WHERE ' + char(13) + @WhereClause
      END

      IF (@SortColumn != '')
      BEGIN
            SET @SortColumn = 'ORDER BY ' + @SortColumn
            IF (@SortOrder != '')
                  BEGIN
                        SET @SortColumn = @SortColumn + ' ' + @SortOrder
                  END
      END
      SET @SQL = 'WITH E AS (
                        SELECT ROW_NUMBER() OVER ('+ @SortColumn +')AS Row,  *
                        FROM  [HrEmployee]
                        '+ @WhereClause +'
                        )
                        SELECT *
                        FROM E
                        WHERE E.Row between '+ CONVERT(nvarchar(10), @StartRowIndex) +' And ('+ CONVERT(nvarchar(10), @StartRowIndex+ @RowPerPage-1) +')'
--    print @SQL
EXEC sp_executesql @SQL


END