【oracle 学习笔记 -6】

本文介绍了一个使用PL/SQL编写的存储过程及包,用于从学生表中检索并打印学生信息,并提供了一个函数来按ID获取特定学生的详细记录。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

create or replace procedure PrintStudentInfo is begin for student_cur in (select * from student) loop dbms_output.put(student_cur.sid || '/'); dbms_output.put(student_cur.sname|| '/'); dbms_output.put_line(student_cur.saddress); end loop; end PrintStudentInfo

create or replace package USER_PKG is TYPE student_info is record ( ID student.sid%type, name student.sname%type, birth student.sbirth%type, addr student.saddress%type ); procedure PrintStudentInfo; function GetStudentInfo(id in varchar2) return student_info; end USER_PKG;

create or replace package body USER_PKG is cursor student_cur is select sid,sname,sbirth,saddress from student; procedure PrintStudentInfo is StudentInfo student_info; begin open student_cur; fetch student_cur into StudentInfo; while student_cur%found loop dbms_output.put(StudentInfo.ID || '/'); dbms_output.put(StudentInfo.name|| '/'); dbms_output.put(StudentInfo.birth|| '/'); dbms_output.put_line(StudentInfo.addr|| '/'); fetch student_cur into StudentInfo; end loop; close student_cur; exception when invalid_cursor then dbms_output.put_line('invalid cursor'); when cursor_already_open then dbms_output.put_line('cursor already open'); end PrintStudentInfo; function GetStudentInfo(id in varchar2) return student_info is StudentInfo student_info; begin select sid,sname, sbirth,saddress into StudentInfo from student where sid = id; return StudentInfo; exception when no_data_found then dbms_output.put_line('no data found'); end GetStudentInfo; end USER_PKG;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值