PL/SQL - 常量和字面量



在本章中,我们将讨论 PL/SQL 中的常量字面量。常量保存一个值,一旦声明,在程序中就不会改变。常量声明指定其名称、数据类型和值,并为其分配存储空间。声明还可以强制执行NOT NULL 约束

声明常量

常量使用CONSTANT关键字声明。它需要一个初始值,并且不允许更改该值。例如 -

PI CONSTANT NUMBER := 3.141592654; 
DECLARE 
   -- constant declaration 
   pi constant number := 3.141592654; 
   -- other declarations 
   radius number(5,2);  
   dia number(5,2);  
   circumference number(7, 2); 
   area number (10, 2); 
BEGIN  
   -- processing 
   radius := 9.5;  
   dia := radius * 2;  
   circumference := 2.0 * pi * radius; 
   area := pi * radius * radius; 
   -- output 
   dbms_output.put_line('Radius: ' || radius); 
   dbms_output.put_line('Diameter: ' || dia); 
   dbms_output.put_line('Circumference: ' || circumference); 
   dbms_output.put_line('Area: ' || area); 
END; 
/ 

当以上代码在 SQL 提示符下执行时,它会产生以下结果 -

Radius: 9.5 
Diameter: 19 
Circumference: 59.69 
Area: 283.53  

Pl/SQL procedure successfully completed. 

PL/SQL 字面量

字面量是显式的数值、字符、字符串或布尔值,不以标识符表示。例如,TRUE、786、NULL、'tutorialspoint' 都是布尔型、数字型或字符串型的字面量。PL/SQL 中,字面量区分大小写。PL/SQL 支持以下几种字面量 -

  • 数值字面量
  • 字符字面量
  • 字符串字面量
  • 布尔字面量
  • 日期和时间字面量

下表提供了所有这些类别字面量的示例。

序号 字面量类型和示例
1

数值字面量

050 78 -14 0 +32767

6.6667 0.0 -12.0 3.14159 +7800.00

6E5 1.0E-8 3.14159e0 -1E38 -9.5e-3

2

字符字面量

'A' '%' '9' ' ' 'z' '('

3

字符串字面量

'Hello, world!'

'Tutorials Point'

'19-NOV-12'

4

布尔字面量

TRUE、FALSE 和 NULL。

5

日期和时间字面量

DATE '1978-12-25';

TIMESTAMP '2012-10-29 12:01:01';

要在字符串字面量中嵌入单引号,请将两个单引号并排放置,如下面的程序所示 -

DECLARE 
   message  varchar2(30):= 'That''s tutorialspoint.com!'; 
BEGIN 
   dbms_output.put_line(message); 
END; 
/  

当以上代码在 SQL 提示符下执行时,它会产生以下结果 -

That's tutorialspoint.com!  

PL/SQL procedure successfully completed.
广告