遍历oracle中得一个表,取出每一列的“name”值。再查出关联这个“name”值的

在oracle中用存储过程实现:遍历oracle中得一个表,取出每一列的“name”值。再查出关联这个“name”值的另一个表有多少条数据,再把这个数据存到一个新表的每一列中
假如有一个“teacher表”,根据名称把所有的老师名字遍历出来。
然后再算出每个老师的学生总数。(老师是主键)。
再新建一个表,有两列。是老师id和学生总数。

第1个回答  2013-04-18
declare
teacher_name varchar(20)------------跟teacher表中老师名字类型保持一致
cursor t_name is select teachername from teacher---------申明游标t_name为从teacher表中查询老师名字
begin
open t_name;------打开游标t_name
loop-------开始循环(遍历)
fetch t_name into teacher_name-------将老师名字值赋予变量teacher_name
if t_name%found-------------开始遍历有值时插入以下数据
then
select name,count(*) into new_table
from table_teacher_student
where name=teacher_name group by name-----将一个老师名字依据条件插入新表数据
else
dmbs_output.put_line(‘完成所有工作’);---------遍历结束时输出完成工作
exit;
end if;
end loop;

仓促写下以上内容,可能部分语法报错,思路就是这样,很基本的一个游标使用。本回答被提问者采纳
相似回答