首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 数据库 > oracle >

一个关于case的简单有关问题,大家帮帮忙

2012-02-26 
一个关于case的简单问题,大家帮帮忙students表如下:SQLselect*fromstudentsROLL_NONAMECLASSSUBJECT1SUB

一个关于case的简单问题,大家帮帮忙
students表如下:

SQL>   select   *   from   students;

      ROLL_NO   NAME           CLASS                 SUBJECT1       SUBJECT2       SUBJECT3
-------   ---------   ----------   ----------   ----------   ----------
            1   张三                 0703                     99                   98                   95
            2   李四                 0703                     95                   90                   85
            3   王五                 0124                     100                 90                   70
            4   赵六                 0124                     85                   90                   80
            5   李小四             0703                     99                   92                   59
            6   赵小六             0124                     100                 89                   40


问题:
要求使用PL/SQL,根据学生得分显示成绩,如果得分> =85,则显示“优秀”,如果> =60,则显示“合格”,否则显示“不及格”。

[解决办法]
declare
p_cursor sys_refcursor;
begin
open p_cursor for select
NAME,
case when SUBJECT1> =85 then '优秀 '
when SUBJECT1> =60 then '合格 '
else '不及格 ' end as col
from students;
end;

热点排行