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

在oracle中用存储过程实现:遍历oracle中得一个表,取出每一列的“name”值。再查出关联这个“name”值的另一个表有多少条数据,再把这个数据存到一个新表的每一... 在oracle中用存储过程实现:遍历oracle中得一个表,取出每一列的“name”值。再查出关联这个“name”值的另一个表有多少条数据,再把这个数据存到一个新表的每一列中
假如有一个“teacher表”,根据名称把所有的老师名字遍历出来。
然后再算出每个老师的学生总数。(老师是主键)。
再新建一个表,有两列。是老师id和学生总数。
展开
 我来答
yfshuai
2013-04-18 · 超过20用户采纳过TA的回答
知道答主
回答量:39
采纳率:0%
帮助的人:38.6万
展开全部
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;

仓促写下以上内容,可能部分语法报错,思路就是这样,很基本的一个游标使用。
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式