码迷,mamicode.com
首页 > 数据库 > 详细

『ORACLE』 PLSQL-case语句(11g)

时间:2017-05-13 21:04:15      阅读:270      评论:0      收藏:0      [点我收藏+]

标签:out   lin   ade   proc   cto   begin   ase   nbsp   arc   

语法:

CASE selector 

WHEN exp1 then res1

WHEN exp2 then res2

WHEN exp3 then res3

...

[ELSE resN]

end;

SQL> declare
2 mygrade char(1):=‘A‘;
3 res varchar2(20);
4 begin
5 res :=
6 CASE mygrade
7 WHEN ‘A‘ THEN ‘The mark is 90-100‘
8 WHEN ‘B‘ THEN ‘The mark is 80-90‘
9 WHEN ‘C‘ THEN ‘The mark is 70-80‘
10 WHEN ‘D‘ THEN ‘The mark is 60-70‘
11 WHEN ‘E‘ THEN ‘The mark is 0-60‘
12 END;
13 dbms_output.put_line(res);
14 end;
15 /
The mark is 90-100

PL/SQL procedure successfully completed.

SQL> 2
2* mygrade char(1):=‘A‘;

SQL> ch /‘A‘/‘F‘/
2* mygrade char(1):=‘F‘;
SQL> l
1 declare
2 mygrade char(1):=‘F‘;
3 res varchar2(20);
4 begin
5 res :=
6 CASE mygrade
7 WHEN ‘A‘ THEN ‘The mark is 90-100‘
8 WHEN ‘B‘ THEN ‘The mark is 80-90‘
9 WHEN ‘C‘ THEN ‘The mark is 70-80‘
10 WHEN ‘D‘ THEN ‘The mark is 60-70‘
11 WHEN ‘E‘ THEN ‘The mark is 0-60‘
12 END;
13 dbms_output.put_line(res);
14* end;
SQL> /

PL/SQL procedure successfully completed.

SQL> declare
2 mygrade char(1):=‘F‘;
3 res varchar2(20);
4 begin
5 res :=
6 CASE mygrade
7 WHEN ‘A‘ THEN ‘The mark is 90-100‘
8 WHEN ‘B‘ THEN ‘The mark is 80-90‘
9 WHEN ‘C‘ THEN ‘The mark is 70-80‘
10 WHEN ‘D‘ THEN ‘The mark is 60-70‘
11 WHEN ‘E‘ THEN ‘The mark is 0-60‘
12 ELSE ‘The mark is null‘
13 END;
14 dbms_output.put_line(res);
15 end;
16 /
The mark is null

PL/SQL procedure successfully completed.

『ORACLE』 PLSQL-case语句(11g)

标签:out   lin   ade   proc   cto   begin   ase   nbsp   arc   

原文地址:http://www.cnblogs.com/KT-melvin/p/6850125.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!