Oracle实验七:PL/SQL 编程基础(2)

实验七:PL/SQL编程基础(2)

 

一、实验目的

1.熟悉掌握PL/SQL编程中游标的定义和使用。

2.熟悉掌握PL/SQL程序的异常处理。

二、实验内容

1、练习使用游标,包括隐式游标、显式游标和游标FOR循环。

(1)在SCOTT模式下显示工资排名前5的员工的编号、姓名和工资,并将所有执行正确的PL/SQL语句记录下来。

①使用隐式游标。

②使用显式游标。

③使用游标for循环

2.预定义异常的应用:在SCOTT模式下,由员工编号(员工编号由用户任意输入)查找EMP表中的某一员工的姓名。若查找成功则显示该员工的姓名若该员工编号不存在、则由教材P136表6-2中系统定义的异常NO_DATA_FOUND,输出用户自定义的错误信息“编号错误,没有找到相应的雇员!”若发生其他类型的错误,则利用OTHERS子句捕获异常,显示自定义错误消息“发生其他错误”、出错码(SQLCODE)以及出错信息(SQLERRM)。

3.自定义异常的应用:自定义一个异常,在SCOTT模式下,如果查找到EMP表中的某一员工(员工编号由用户任意输入)的佣金(COMM字段)为0时,则显示自定义错误消息“该员工的佣金为0,请检查数据是否有误!”。

实验七附加:PL/SQL编程基础(2)

一、实验目的

1.熟悉掌握PL/SQL编程中游标的定义和使用。

2.熟悉掌握PL/SQL程序的异常处理。

二、实验内容

1、练习使用游标(带参游标)。

用显式游标查询SCOTT模式下emp表中某部门某工种的员工编号(empno)和姓名(ename),要求:显式游标的参数为该员工的部门号(deptno)和工种(job),利用带参数的显式游标根据部门号和工种这两个参数,显示该部门、该工种的员工编号和姓名信息。例如,若给定的参数是部门号(10),工种(CLERK),则显示部门号为10、工种为CLERK的员工的编号和姓名。请将所有执行正确的PL/SQL语句记录下来。

2.非预定义异常的应用:

已知Oracle中一错误代码ORA-01400: 无法将 NULL 插入,请将该错误代码与NULL_INSERT_ERROR进行关联,并利用Scott模式下的表(例如,emp或dept)操作,举例报出该错误。

关注我,了解更多精彩内容! 

  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
Oracle PL/SQLOracle数据库的编程语言,它允许开发人员编写存储过程、触发器、函数和包等数据库对象,以实现更高效、安全和可靠的应用程序。以下是一些Oracle PL/SQL必知必会的知识点: 1. PL/SQL基础语法:包括变量定义、控制结构、循环语句、异常处理等。 2. 存储过程:存储过程是一组SQL语句的集合,可以在其中定义变量、使用控制结构、调用其他存储过程等。 3. 触发器:触发器是一种特殊的存储过程,它会在数据库表上的特定事件发生时自动执行一些操作。 4. 函数:函数是一种可以接受输入参数并返回结果的代码块,它可以用于处理数据、计算等操作。 5. 包:包是一种可以封装存储过程、函数和变量的方式,它可以提供更好的代码管理和组织。 6. 游标:游标是一种可以遍历查询结果集的机制,它可以用于在PL/SQL中处理大量数据。 7. 动态SQL:动态SQL是一种可以在运行时构建和执行SQL语句的机制,它可以提供更大的灵活性和自由度。 8. 性能优化:在编写PL/SQL代码时需要注意性能问题,如尽量避免使用循环、减少数据库访问次数等。 9. 安全性:在编写PL/SQL代码时需要注意安全问题,如避免SQL注入攻击、对敏感数据进行加密等。 以上是Oracle PL/SQL必知必会的一些知识点,掌握它们可以帮助开发人员更好地使用Oracle数据库进行应用程序开发。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

不服输的小乌龟

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值