首頁 資料庫 mysql教程 Oracle PL/SQL开发利器

Oracle PL/SQL开发利器

Jun 07, 2016 pm 03:45 PM
or oracle sql 使用 利器 開發 進行

使用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示例:

 

<ol>
<li><span><span>CREATE</span><span> </span><span>OR</span><span> </span><span>REPLACE</span><span> </span><span>PROCEDURE</span><span> SCOTT.calc_totalTemp (fudge_factor_in </span><span>IN</span><span> NUMBER) </span></span></li>
<li><span><span>IS</span><span> </span></span></li>
<li><span>  subtotal NUMBER := 0; </span></li>
<li><span>  <span>PROCEDURE</span><span> compute_running_total (increment_in </span><span>IN</span><span> PLS_INTEGER) </span></span></li>
<li><span>  <span>IS</span><span> </span></span></li>
<li><span>  <span>BEGIN</span><span> </span></span></li>
<li><span>  subtotal := subtotal + increment_in * fudge_factor_in; </span></li>
<li><span>  <span>END</span><span>; </span></span></li>
<li><span><span>BEGIN</span><span> </span></span></li>
<li><span>  <span>FOR</span><span> month_idx </span><span>IN</span><span> 1..12 </span></span></li>
<li><span>  LOOP </span></li>
<li><span>    compute_running_total (month_idx); </span></li>
<li><span>  <span>END</span><span> LOOP; </span></span></li>
<li><span>  DBMS_OUTPUT.PUT_LINE(<span>'Fudged total for year: '</span><span> || subtotal); </span></span></li>
<li><span><span>END</span><span>; </span></span></li>
<li><span>/ </span></li>
</ol>
登入後複製
  •  Function示例

 

<ol>
<li><span><span>CREATE</span><span> </span><span>OR</span><span> </span><span>REPLACE</span><span> </span><span>FUNCTION</span><span> SCOTT.wordcountTemp (str </span><span>IN</span><span> VARCHAR2) </span></span></li>
<li><span><span>RETURN</span><span> PLS_INTEGER </span></span></li>
<li><span><span>AS</span><span> </span></span></li>
<li><span>/* words PLS_INTEGER := 0; ***Commented <span>out</span><span> </span><span>for</span><span> intentional error*** */ </span></span></li>
<li><span>words PLS_INTEGER := 0; </span></li>
<li><span>len PLS_INTEGER := NVL(LENGTH(str),0); </span></li>
<li><span>inside_a_word BOOLEAN; </span></li>
<li><span><span>BEGIN</span><span> </span></span></li>
<li><span><span>FOR</span><span> i </span><span>IN</span><span> 1..len + 1 </span></span></li>
<li><span>LOOP </span></li>
<li>
<span>IF ASCII(SUBSTR(str, i, 1)) OR</span><span> i > len </span>
</li>
<li><span><span>THEN</span><span> </span></span></li>
<li><span>IF inside_a_word </span></li>
<li><span><span>THEN</span><span> </span></span></li>
<li><span>words := words + 1; </span></li>
<li><span>inside_a_word := <span>FALSE</span><span>; </span></span></li>
<li><span><span>END</span><span> IF; </span></span></li>
<li><span><span>ELSE</span><span> </span></span></li>
<li><span>inside_a_word := <span>TRUE</span><span>; </span></span></li>
<li><span><span>END</span><span> IF; </span></span></li>
<li><span><span>END</span><span> LOOP; </span></span></li>
<li><span><span>RETURN</span><span> words; </span></span></li>
<li><span><span>END</span><span>; </span></span></li>
<li><span>/ </span></li>
</ol>
登入後複製

  (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):

 

<ol>
<li><span><span>grant</span><span> debug </span><span>connect</span><span> session </span><span>to</span><span> scott; </span></span></li>
<li><span><span>grant</span><span> debug </span><span>any</span><span> </span><span>procedure</span><span> </span><span>to</span><span> scott; </span></span></li>
</ol>
登入後複製

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

   (5)Connection Color-Coding

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

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

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

 

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

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1664
14
CakePHP 教程
1421
52
Laravel 教程
1315
25
PHP教程
1266
29
C# 教程
1239
24
oracle游標關閉怎麼解決 oracle游標關閉怎麼解決 Apr 11, 2025 pm 10:18 PM

解決 Oracle 游標關閉問題的方法包括:使用 CLOSE 語句顯式關閉游標。在 FOR UPDATE 子句中聲明游標,使其在作用域結束後自動關閉。在 USING 子句中聲明游標,使其在關聯的 PL/SQL 變量關閉時自動關閉。使用異常處理確保在任何異常情況下關閉游標。使用連接池自動關閉游標。禁用自動提交,延遲游標關閉。

oracle怎麼循環創建游標 oracle怎麼循環創建游標 Apr 12, 2025 am 06:18 AM

Oracle 中,FOR LOOP 循環可動態創建游標, 步驟為:1. 定義游標類型;2. 創建循環;3. 動態創建游標;4. 執行游標;5. 關閉游標。示例:可循環創建游標,顯示前 10 名員工姓名和工資。

HDFS配置CentOS需要哪些步驟 HDFS配置CentOS需要哪些步驟 Apr 14, 2025 pm 06:42 PM

在CentOS系統上搭建Hadoop分佈式文件系統(HDFS)需要多個步驟,本文提供一個簡要的配置指南。一、前期準備安裝JDK:在所有節點上安裝JavaDevelopmentKit(JDK),版本需與Hadoop兼容。可從Oracle官網下載安裝包。環境變量配置:編輯/etc/profile文件,設置Java和Hadoop的環境變量,使系統能夠找到JDK和Hadoop的安裝路徑。二、安全配置:SSH免密登錄生成SSH密鑰:在每個節點上使用ssh-keygen命令

oracle日誌寫滿怎麼辦 oracle日誌寫滿怎麼辦 Apr 12, 2025 am 06:09 AM

Oracle 日誌文件寫滿時,可採用以下解決方案:1)清理舊日誌文件;2)增加日誌文件大小;3)增加日誌文件組;4)設置自動日誌管理;5)重新初始化數據庫。在實施任何解決方案前,建議備份數據庫以防數據丟失。

甲骨文在商業世界中的作用 甲骨文在商業世界中的作用 Apr 23, 2025 am 12:01 AM

Oracle不僅是數據庫公司,還是雲計算和ERP系統的領導者。 1.Oracle提供從數據庫到雲服務和ERP系統的全面解決方案。 2.OracleCloud挑戰AWS和Azure,提供IaaS、PaaS和SaaS服務。 3.Oracle的ERP系統如E-BusinessSuite和FusionApplications幫助企業優化運營。

oracle數據庫怎麼停止 oracle數據庫怎麼停止 Apr 12, 2025 am 06:12 AM

要停止 Oracle 數據庫,請執行以下步驟:1. 連接到數據庫;2. 優雅關機數據庫(shutdown immediate);3. 完全關機數據庫(shutdown abort)。

oracle視圖怎麼導出 oracle視圖怎麼導出 Apr 12, 2025 am 06:15 AM

可以通過 EXP 實用程序導出 Oracle 視圖:登錄 Oracle 數據庫。啟動 EXP 實用程序,指定視圖名稱和導出目錄。輸入導出參數,包括目標模式、文件格式和表空間。開始導出。使用 impdp 實用程序驗證導出。

centos上weblogic的數據庫連接如何配置 centos上weblogic的數據庫連接如何配置 Apr 14, 2025 pm 02:06 PM

在CentOS系統上配置WebLogic數據庫連接,需要完成以下步驟:JDK安裝與環境配置:確保服務器已安裝與WebLogic版本兼容的JDK(例如,WebLogic14.1.1通常需要JDK8)。正確設置JAVA_HOME、CLASSPATH和PATH環境變量。 WebLogic安裝與解壓:從Oracle官方網站下載適用於CentOS系統的WebLogic安裝包,並將其解壓到指定目錄。 WebLogic用戶與目錄創建:創建一個專用的WebLogic用戶賬戶,並設置安全密碼

See all articles