日期:2014-05-17  浏览次数:20966 次

菜鸟求教:如何吧一张表的某字段的值变成结果集的字段
比如现在有三张表:
表1是学生信息表(student),有字段id,name
-----------------
  id   |   name
-----------------
  1    |   张三
-----------------
表2是科目表(course),有字段id,name
-----------------
  id   |   name
-----------------
  1    |   语文
-----------------
  2    |   数学
-----------------
  3    |   英语
-----------------
表3是成绩表(score),有字段id, student_id, course_id, score
-------------------------------------------------
  id   |   student_id   |   course_id   |   score
-------------------------------------------------
  1    |        1       |       1       |     70
-------------------------------------------------
  2    |        1       |       2       |     80
-------------------------------------------------
  3    |        1       |       3       |     81
--------------------------------------------------

现在需求是用SQL语句输出结果集的形式是:
-------------------------------------------------
  student_name  |   语文  |   数学   |   英语  
-------------------------------------------------
     张三       |   70    |    80    |    81
-------------------------------------------------

求大神指教....   

------解决方案--------------------
with student as (select 1 id, '张三' name from dual),
      score  as ( select 1 id, 1 student_id, 1 course_id, 70 score from dual
                   union all
                  select 1 id, 1 student_id, 2 course_id, 80 score from dual
                   union all
                  select 1 id,&nb