热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

OraclePL/SQL开发利器

使用Toad进行OraclePLSQLProgram的编写及调试需掌握如下视图应用:(1)SchemaBroswer模式浏览器(SchemaBrowser)可以快速访问数据字典,浏览数据库中的表、索引、存储过程。Toad提供对数据库的快速访问,使用极为方便,用户界面简洁,结构安排合

使用Toad进行Oracle PL/SQL Program的编写及调试需掌握如下视图应用: (1)Schema Broswer 模式浏览器(Schema Browser)可以快速访问数据字典,浏览数据库中的表、索引、存储 过程。Toad 提供对数据库的快速访问,使用极为方便,用户界面简洁,结构安排合

使用Toad进行Oracle PL/SQL Program的编写及调试需掌握如下视图应用:

(1)Schema Broswer

模式浏览器(Schema Browser)可以快速访问数据字典,浏览数据库中的表、索引、存储

过程。Toad 提供对数据库的快速访问,使用极为方便,用户界面简洁,结构安排合理。当点击

一个单独的数据库对象,Toad 立即显示此对象的详细信息。例如,点一个数据库的表,所有和

此表相关的索引、约束、存储过程、SQL 语句、表中的数据以及和其他表的相互引用关系都在

同一界面显示出来。所有针对数据库对象的操作都可以在Schema Browser 一个窗口中进行。

开发人员查询Oracle数据库当前用户连接的所有对象信息,开发中可由这里浏览各种对象,即Procedure、Function、Package,单击某个对象即走读相关代码,右击可实现重新编译等操作,双击某对象进入对应的开发编辑视图,可进行修改、调试、语句跟踪性能分析等操作;

(2)SQL Editor

SQL 编辑器(SQL Editor)的主要功能是编辑、运行和调整SQL 语句。TOAD 的高级编

辑窗口包括众多的特性来提高开发人员编写SQL 语句的产品化程度。例如,简单地生成代码模

板,在编写SQL 前自动发现包的内容和列的名字等等。SQL 编辑器包括一个编辑窗口和运行结

果窗口,允许开发人员在编辑的过程中测试运行结果。SQL 编辑器中不仅包括标准的编辑命令,

也包括一些增强的功能,如快速查询表中的字段、将SQL 语句的内容格式化等等。这个窗口可

以处理大到4GB 的内容,对大的开发项目来说非常有用。便捷的书签可以让开发人员非常容易

地找到相关位置。在运行结果窗口可提供用户定义的配置功能,支持LONG 和LONG RAW 列,

可以将数据卸出到磁盘、打印数据、编辑数据等等。

(3)Procedure Editor

存储过程编辑器(Procedure Editor)的主要功能是编辑、编译、测试、调试存储过程和触

发器。TOAD 提供语法标识、错误标识和其他很多易于使用的功能,如在弹出窗口显示表名、列

名和Oracle 函数。和其他的 PL/SQL 编辑工具不同,TOAD 允许在一个文件中操作多个数据

库对象,可以编译一个对象、编译多个对象、编译到当前光标、从光标开始编译。在运行出现错

误时,存储过程停止到有问题的语句。用户可以使用快捷方式或模板来快速编写PL/SQL,也可以

根据需要生成自己的模板。使用Toad 可以非常方便地进行编辑工作,可如设置书签、取消注释、

格式化SQL 语句等等。

写两个实例如下:

  • Procedure示例:

  1. CREATE OR REPLACE PROCEDURE SCOTT.calc_totalTemp (fudge_factor_in IN NUMBER)
  2. IS
  3. subtotal NUMBER := 0;
  4. PROCEDURE compute_running_total (increment_in IN PLS_INTEGER)
  5. IS
  6. BEGIN
  7. subtotal := subtotal + increment_in * fudge_factor_in;
  8. END;
  9. BEGIN
  10. FOR month_idx IN 1..12
  11. LOOP
  12. compute_running_total (month_idx);
  13. END LOOP;
  14. DBMS_OUTPUT.PUT_LINE('Fudged total for year: ' || subtotal);
  15. END;
  16. /
  • Function示例

  1. CREATE OR REPLACE FUNCTION SCOTT.wordcountTemp (str IN VARCHAR2)
  2. RETURN PLS_INTEGER
  3. AS
  4. /* words PLS_INTEGER := 0; ***Commented out for intentional error*** */
  5. words PLS_INTEGER := 0;
  6. len PLS_INTEGER := NVL(LENGTH(str),0);
  7. inside_a_word BOOLEAN;
  8. BEGIN
  9. FOR i IN 1..len + 1
  10. LOOP
  11. IF ASCII(SUBSTR(str, i, 1)) <33 OR i > len
  12. THEN
  13. IF inside_a_word
  14. THEN
  15. words := words &#43; 1;
  16. inside_a_word := FALSE;
  17. END IF;
  18. ELSE
  19. inside_a_word := TRUE;
  20. END IF;
  21. END LOOP;
  22. RETURN words;
  23. END;
  24. /

(4)PL/SQL Debugger

Toad 提供强大易用的PL/SQL 调试功能,可以节省开发人员在大型项目中用于开发和测

试的宝贵时间,提高应用开发的质量。在存储过程开发的过程中,Toad 可以逐行编辑、调试和

运行代码。运行时可以根据需要输入参数,观察相关参数的变化来检查存储过程的正确性。在调

式过程中,Toad 可以通过窗口显示所有的断点、参数, 调用堆栈和输出参数。使用Toad,非

常容易检测到存储过程的错误,开发人员可以一步一步运行PL/SQL 语句来识别问题。调试会话

可以和其他程序会话同时进行。

我在刚开始使用Toad对Procedure和Function进行调试的时候,出现了调试按钮置灰无法进行调试、点击调试按钮后程序直接跑完没有在断点处停住等情况,在网上查了很久,大都对这个问题都没有人进行正确的解决;

解决Toad调试的问题的方法如下:

首先确认一点:你当前Toad的用户连接是否为Sys、System等DBA用户,如果是的话,就会出现Toad Debug按钮是可用的,断点也可以设置,但是程序直接跑完的情况,应该是Toad不支持DBA用户直接调试PL/SQL程序;

然后,将用户连接改为其他用户例如Scott重连Toad,当Toad在此用户连接下,直接进行调试PL/SQL是不行的,因为该用户默认是没有Debugger权限的,在此情况下Debug按钮也是置灰的;

然后,执行如下语句,(假设当前Toad连接Oracle的用户为Toad):

  1. grant debug connect session to scott;
  2. grant debug any procedure to scott;

最后,就跟在Eclipse Debug Java程序差不多了,即设置断点,点击Toad上的按钮Execute PL/SQL with Debugger,那就开始调试吧!

(5)Connection Color-Coding

Toad 允许同时连接多个数据库,便于在多个数据库之间进行切换和比对。但是这样也增加

了在数据库上进行误操作的风险。Connection Color-Coding 允许用户在定义一个新的数据库连

接时,为该连接指定一种颜色,以便作为醒目提醒。

中子星” 博客,请务必保留此出处http://ckitpro8086.blog.51cto.com/3653012/770589

推荐阅读
  • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
  • 在安装 SQL Server 时,选择混合验证模式可以提供更高的灵活性和管理便利性。如果您已经安装了 SQL Server 并使用单一的 Windows 身份验证模式,可以通过以下步骤将其更改为混合验证模式。 ... [详细]
  • 本文介绍了在 SQL Server 2012 客户端中格式化 SQL 查询语句的多种方法,包括内置功能和第三方工具,帮助用户提高代码可读性和维护性。 ... [详细]
  • 本文介绍了一个基于 Java SpringMVC 和 SSM 框架的综合系统,涵盖了操作日志记录、文件管理、头像编辑、权限控制、以及多种技术集成如 Shiro、Redis 等,旨在提供一个高效且功能丰富的开发平台。 ... [详细]
  • MySQL Debug 模式的实现与应用
    本文详细介绍了如何启用和使用 MySQL 的调试模式,包括编译选项、环境变量配置以及调试信息的解析。通过实际案例展示了如何利用调试模式解决客户端无法连接服务器的问题。 ... [详细]
  • 如何从python读取sql[mysql基础教程]
    从python读取sql的方法:1、利用python内置的open函数读入sql文件;2、利用第三方库pymysql中的connect函数连接mysql服务器;3、利用第三方库pa ... [详细]
  • 深入解析 Apache Shiro 安全框架架构
    本文详细介绍了 Apache Shiro,一个强大且灵活的开源安全框架。Shiro 专注于简化身份验证、授权、会话管理和加密等复杂的安全操作,使开发者能够更轻松地保护应用程序。其核心目标是提供易于使用和理解的API,同时确保高度的安全性和灵活性。 ... [详细]
  • 本文探讨了在Java中实现系统托盘最小化的两种方法:使用SWT库和JDK6自带的功能。通过这两种方式,开发者可以创建跨平台的应用程序,使窗口能够最小化到系统托盘,并提供丰富的交互功能。 ... [详细]
  • 本文总结了Java程序设计第一周的学习内容,涵盖语言基础、编译解释过程及基本数据类型等核心知识点。 ... [详细]
  • 创建项目:Visual Studio Online 入门指南
    本文介绍如何使用微软的 Visual Studio Online(VSO)创建和管理开发项目。作为一款基于云计算的开发平台,VSO 提供了丰富的工具和服务,简化了项目的配置和部署流程。 ... [详细]
  • 本文介绍如何在 Visual Studio Code 中使用 Jupyter Notebook 插件,包括创建、编辑和运行笔记本的基本操作。 ... [详细]
  • 本文将带您了解Cocos家族的不同版本和分支,特别是Cocos Creator的发展历程及其核心特性,帮助初学者快速入门。 ... [详细]
  • 俗话说得好,“工欲善其事,必先利其器”。这句话不仅强调了工具的重要性,也提醒我们在任何项目开始前,准备合适的工具至关重要。本文将介绍几款C语言编程中常用的工具,帮助初学者更好地选择适合自己学习和工作的编程环境。 ... [详细]
  • 使用M函数轻松处理Excel中的多分隔符分列问题
    在处理Excel数据时,经常会遇到需要根据不同的分隔符来拆分单元格中的内容。本文介绍了一种利用M函数在Power Query中实现这一需求的方法,即使面对多种分隔符也能轻松应对。 ... [详细]
  • 尝试利用Delphi6中的Indy组件实现ASP自动登录功能时遇到了问题。在尝试复现网络上找到的一个示例代码时,程序无法正常编译运行,报错信息指出Post方法没有适用的重载版本。 ... [详细]
author-avatar
公安边防临高支队警务微博_821
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有