• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >oracle > PL/SQL编程经验小结开发者网络Oracle

PL/SQL编程经验小结开发者网络Oracle

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-11

通过本文主要向大家介绍了pl/sql连接oracle,oracle pl/sql,精通oracle pl/sql,oracle pl/sql入门,oracle pl/sql编程等相关知识,希望本文的分享对您有所帮助
正在看的ORACLE教程是:PL/SQL编程经验小结开发者网络Oracle。平时在PL/SQL中的编程中遇到一些问题,这里以问答的形式来进行把它们总结下来,以供大家分享。

  1、当需要向表中装载大量的数据流或者需要处理大量的数据流的时候,能否使用管道提高处理效率?
管道函数对于改善并行查询的性能非常方便,它加快往表中加载数据的速度。管道函数的使用总结如下两点:

  每当在查询里使用PL/SQL函数时,该查询将被序列化,即一个处理器只能运行一个查询实例,那么在这种情况下不可能使用并行查询(比如在数据仓库中要经常使用这项技术)。因此,为了使用并行查询就必须使用管道函数,这样也就加快了执行的速度。

  管道函数的输入参数必须是一个引用记录集类型(即ref cursor),而返回的是嵌套表类型(其表中每一行对应每一个引用记录)。在使用管道函数之前,必须先在程序头写上PARALLEL_ENABLE,这样才能在查询语句中使用管道函数来处理了。

  2. 如何使PL/SQL程序等待一段时间执行?
 
  方法就是使用DBMS_LOCK包的SLEEP函数,可以进行精确定时,其语法为:

DBMS_LOCK.SLEEP (seconds IN NUMBER);

  3.需要在一张表插入一条记录之后等若干秒后再执行另外一个操作,如何在PL/SQL程序里进行定时操作? 

  一般的做法是用循环作延迟,利用 DBMS_UTILITY的gettime函数来检测当前的时间,程序代码如下:


   另外如果是不同会话(session)之间的定时,就必须使用DBMS_PIPE包的函数来实现会话间的消息传递。

  4.当PL/SQL返回一个数据集的时候,该使用集合还是游标?

  一般情况下,有以下两点作为依据:

  1) 如果PL/SQL程序返回多多行数据给另外一个PL/SQL程序的话,这里就建议使用集合,因为这样可以利用集合的批收集(bulk collection)来提高从数据库提取数据的速度。

  2) 如果需要在PL/SQL程序的环境中把数据返回到宿主语言环境中(如Sql*plus,c,delphi等),这时应该使用游标变量来返回这些数据,因为几乎所有的宿主语言都支持游标变量,但不是所有的宿主语言都支持集合。这样可以增强程序的可移植性。

  5.如何更有效的在PL/SQL中使用游标?

  游标是PL/SQL中一个非常重要的概念,对数据库的检索主要依靠游标来操作。在PL/SQL中有两类游标,一类是隐式游标,如select clno into v_clno from table_detail.另外一类是显式游标,如cursor v_cur is select clno from table_detail。对于游标的使用这里给出以下几点建议:

  1) 尽可能的使用bulk collection。它能够较大的提高运行性能,在Oracl9i的第二版,甚至可以使用bulk collection来直接将数据写入到记录表

  2) 尽量使用显式游标来处理,因为相对于隐式游标来说,显式游标的速度更快一些。

  3) 如果查询的表很小或者是静态的,可以把该表缓存到一个包级的集合里。这样,你的查询函数就直接从集合里(即进程全局区,PGA cache),而不是从系统全局区(SGA)来取数据,这样的处理速度会提升很多。

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • PL/SQL Developer连接64位的Oracle图文教程
  • PL/SQL远程备份和恢复Oracle数据库
  • PL/SQL Dev连接Oracle弹出空白提示框的解决方法分享
  • PL/SQL编程经验小结开发者网络Oracle

相关文章

  • 2017-05-11Oracle最大日期获取方法
  • 2017-12-17oracle里IW和WW 区别
  • 2017-05-11Linux下Oracle删除用户和表空间的方法
  • 2017-05-11EXECUTE IMMEDIATE用法小结
  • 2017-05-11Oracle多表级联更新详解
  • 2017-05-11ORACLE 常用函数总结(80个)第1/2页
  • 2017-05-11修改Oracle监听默认端口号1521的方法
  • 2017-05-11Oracle数据库密码重置、导入导出库命令示例应用
  • 2017-05-11在Oracle数据库中添加外键约束的方法详解
  • 2017-05-11Oracle 忘记密码的找回方法

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • Oracle常用命令大全集
    • Oracle 随机数
    • oracle实现多行合并的方法
    • Oracle SQL中实现indexOf和lastIndexOf功能的思路及代码
    • Oracle RMAN快速入门指南
    • expdp 中ORA-39002、ORA-39070错误详解及解决办法
    • Oracle密码文件的使用和维护第1/3页
    • Oracle 用户权限管理方法
    • Oracle Number型的深入理解
    • Oracle7.X 回滚表空间数据文件误删除处理方法

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有