大脑神志不清的原因:SQL中变量的种类及表现形式

来源:百度文库 编辑:高校问答 时间:2024/04/29 07:01:04
拜托路过的各位高手,这个是我考试的题目,麻烦告诉我答案.谢谢~~

MS SQL Server中的变量- -

在SQL中,我们常常使用临时表来存储临时结果,对于结果是一个集合的情况,这种方法非常实用,但当结果仅仅是一个数据或者是几个数据时,还要去建一个表,显得就比较麻烦,另外,当一个SQL语句中的某些元素经常变化时,比如选择条件,(至少我想)应该使用局部变量。当然MS SQL Server的全局变量也很有用。

>>>>局部变量

声明:DECLARE @local_variable data_type

@local_variable 是变量的名称。变量名必须以 at 符 (@) 开头。data_type 是任何由系统提供的或用户定义的数据类型。变量不能是 text、ntext 或 image 数据类型。

示例:
use master
declare @SEL_TYPE char(2)
declare @SEL_CUNT numeric(10)
set @SEL_TYPE = 'U'/*user table*/
set @SEL_CUNT = 10

/*返回系统中用户表的数目*/
select @SEL_CUNT = COUNT(*)
from sysobjects
where type = @SEL_TYPE

select @SEL_CUNT as 'User table ''s count'

如果要返回系统表的数目,可以用set @SEL_TYPE = 'S'

可能这个例子并不能说明使用变量的好处,我只是想说明使用方法。当一组(几个甚至几十个)SQL语句都使用某个变量时,就能体会到他的好处了。

>>>>全局变量

全局变量是系统预定义的,返回一些系统信息,全局变量以两个at(@)开头。下面是我统计了一些较为常用的变量。

@@CONNECTIONS
返回自上次启动以来连接或试图连接的次数。

@@CURSOR_ROWS
返回连接上最后打开的游标中当前存在的合格行的数量。

@@DATEFIRST
返回每周第一天的数字

@@ERROR
返回最后执行的SQL 语句的错误代码。

@@FETCH_STATUS
返回被 FETCH 语句执行的最后游标的状态,而不是任何当前被连接打开的游标的状态。

@@IDENTITY
返回最后插入的标识值

@@LANGID
返回当前所使用语言的本地语言标识符(ID)。

@@LANGUAGE
返回当前使用的语言名。

@@LOCK_TIMEOUT
返回当前会话的当前锁超时设置,单位为毫秒。

@@PROCID
返回当前过程的存储过程标识符 (ID) 。

@@ROWCOUNT
返回受上一语句影响的行数。

@@SERVERNAME
返回运行 的本地服务器名称。

@@SPID
返回当前用户进程的服务器进程标识符 (ID)。

@@TRANCOUNT
返回当前连接的活动事务数。

@@VERSION
返回当前安装的日期、版本和处理器类型。

是VB里的吗?做网页ASP里用的不是很多