一般情況下,我們喜歡使用Session儲存我們的變量。Asp.Net提供了下面一些方法儲存Session的值:
InProc
State Server
SQL Server
“InProc”表示我們使用傳統ASP一樣的方法儲存Session的值,而且“State Server”則表示使用另外一台主機來儲存Session的值。當然我們也能使用SQL Server儲存值,我們這篇文章就專門用於講解這種方法。
運行InstallSqlState.sql文件
首先需要在WinntMicrosoft.Net中找到InstallSqlState.sql文件,然後在SQL Server 中執行它。在我的機器中,它存在於E:WINNTMicrosoft.NETFrameworkv1.0.2914目錄中。這個文件是微軟自己提供的,裡面有很全的SQL語句,大家放心使用。下圖就是生成的數據表。
修改你的web.config文件,指定Session的mode為SQL Server
將web.config的sessionState部分改成:
<sessionState mode="SQLServer"
sqlConnectionString="data source=
WIN2000;userid=
sa;password=" cookieless= "false"timeout=
"20" />
創建Asp.Net Web Forms
下面就建立一個測試的ASP.net程序,使用Session程序這裡就不用多說了,下面是我的程序的截圖。這個程序只是簡單的儲存一個字符串數據於Session中,然後再顯示這個數據在Label控件中。
現在所有的Session變量都儲存在數據表中,而不是內存中了。你可打開ASPStateTempSessions表來查看這些Session數據了。
刪除這些數據庫和表
如果你不喜歡這個數據儲存方式,看得實在是不爽,那麼你可以把這些表和數據庫完全刪除掉。這個也不要擔心這種刪除會影響數據庫(因為害怕誤刪除一些數據),因為微軟同樣也得供給你們一個刪除SQL 文件,名叫UnintallSQLState.sql。它與IntallSQLState.sql一樣放在.Net的Config目錄中。