oracle--SQL 变量

转载 2007年09月22日 21:40:00
Transact-SQL中可以使用两种变量,一种是局部变量(Local Variable)另外一种是全局变量(Global Variable)。
  
  4.4.1 局部变量
  
  局部变量是用户可自定义的变量,它的作用范围仅在程序内部。在程序中通常用来储存从表中查询到的数据,或当作程序执行过程中暂存变量使用。局部变量必须以“@”开头,而且必须先用DECLARE命令说明后才可使用。其说明形式如下:
  
  DECLARE @变量名 变量类型 [@变量名 变量类型…]
  
  其中变量类型可以是SQL Server 2000支持的所有数据类型,也可以是用户自定义的数据类型。DECLARE命令的详细用法请参见“4.6其它命令”。
  
  在Transact-SQL中不能像在一般的程序语言中一样使用“变量=变量值”来给变量赋值。必须使用SELECT或SET命令来设定变量的值,其语法如下:
  
  SELECT@局部变量=变量值
  
  SET @局部变量=变量值
  
  例4-5:声明一个长度为10 个字符的变量“id”并赋值
  
  declare@id char(10)
  select@id=‘10010001’
  
  注意:可以在Select命令查询数据时,在Select命令中直接将列值赋给变量。例4-6:查询编号为“10010001”的员工和工资,将其分别赋予变量name和wage。
  
  例4-6
  
  use pangu
  declare@name char(30)@wage money
  select@name=e_name,@wage=e_wage
  from employee
  where emp_id='10010001'
  select@name as e_name,@wage as e_wage
  
  运行结果如下:
  
  e_name e_wage
  ------------------------------ -----------
  张三 8000.0000
  
  注意:数据库语言和编程语言有一些关键字,关键字是在某一一样下能够促使某一操作发生的字符组合,为避免冲突和产生错误,在命令表、列、变量以及其它对象时应避免使用关键字。有关SQL Server的关键字请参见附录。
  
  4.4.2 全局变量
  
  全局变量是SQL Server系统内部使用的变量,其作用范围并不局限于某一程序,而是任何程序均可随时调用全局变量通常存储一些SQL Server的配置设定值和效能统计数据。用户可在程序中用全局变量来测试系统的设定值或Transact-SQL命令执行后的状态值。有关SQL Server 全局变量的详细情况请参见附录。
  
  注意:全局变量不是由用户的程序定义的,它们是在服务器级定应义的。只能使用预先说明及定义的变局变量。引用全局变量时,必须以“@@”开头。局部变量的名称不能与全局变量的名称相同、否则会在应用中出错。 

相关文章推荐

在JAVA 源程序中编写SQL语句时使用ORACLE 绑定变量

在JAVA 源程序中编写SQL语句时使用ORACLE 绑定变量 在JAVA 源程序中编写SQL语句时使用ORACLE 绑定变量( bind variable ) 在JAVA中的SQL 语句...

Oracle数据库SQL语句绑定变量二----安全问题

如果没有使用绑定变量,就会有“SQL注入”的危险,下面通过一个例子来说明,这个例子摘自THomas的《Oracle编程艺术深入理解数据库体系结构》。 首先创建过程inj: create or repl...

Oracle数据库SQL语句绑定变量一----性能问题

SQL语句编写时,一般都是这样的: select * from emp where empno=7369; 或者select * from emp where empno=7499; 这两条SQL语句...

Oracle pl/sql编程 8---复合变量之记录表类型

复合变量之记录表类型 记录表类型是对记录类型的扩张,它可以处理多个记录或多行数据,使用记录表类型和记录类型一样想,必须先创建一个记录表类型: type talbe_name i...

Oracle pl/sql编程 7---复合变量之记录类型

复合变量之记录类型 标量变量只可以保存单个数值,在pl/sql中的与标量变量相对应的是复合变量。复合变量可以将不同数据类型的多个值存储在一个单元中。由于复合数据类型可以由用户自己根据需要定义结构所以...

oracle和sqlserver在过程sql中通过select对变量进行赋值的区别及实例

变量的声明: oracle的变量必须在在declare部分声明——意思是必须建立begin end块,块结构也强制变量必须先声明后使用,即oracle变量在过程内是有不同作用域、不同的生存期的;...

Oracle定义PL/SQL变量

Oracle定义PL/SQL变量 前言:使用变量可以保存计算机需要处理的数据,为了给该变量分配适当的内存空间,还需要指定数据类型,有的数据类型还需要指定长度,如字符串。有些类型可以用于建表(如char...

Oracle pl/sql编程 2---plsql变量与常量

PL/SQL中的变量与常量 PL/SQL 标识符 1:变量必须以字母A-Z开头 2:Oracle标示符不区分大小写 3:变量名长度不能超过30个字符 4:标识附中不能包含减号“-”和空格(注...

Oracle(21)pl/sql编程 语法、变量

pl/sql的数据类型分为:标量类型(scalar)、复合类型(composite)、参照类型(reference)、lob(large object)—————————————————————–①标...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:oracle--SQL 变量
举报原因:
原因补充:

(最多只允许输入30个字)