一般情况下,我们喜欢使用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目录中。
相关文章
- 如何将SQL Server时间值绑定到ASP.Net Web表单中的下拉列表?
- 在SQL Server 2008中使用xml和存储过程将数据插入到表中
- SQL Server——将同一表中的一列的值更新到另一列
- 将一列中的所有值与SQL Server中具有逗号分隔值的相同ID组合在一起
- 请教如何将sql server数据库中的datetime字段值都更改为日期型不要时间只显示日期.
- 如何将程序中读到的变量的值写入SQL Server数据库中
- 如何将现有的SQL Server存储过程添加到源代码控制中?
- 在SQL Server 2005中将值CASTing到FLOAT时出错
- SQL SERVER使用REPLACE将某一列字段中的某个值替换为其他的值
- SQL Server存储过程中使用表值作为输入参数示例