使用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

MySQL은 초보자가 데이터베이스 기술을 배우는 데 적합합니다. 1. MySQL 서버 및 클라이언트 도구를 설치하십시오. 2. SELECT와 같은 기본 SQL 쿼리를 이해하십시오. 3. 마스터 데이터 작업 : 데이터를 만들고, 삽입, 업데이트 및 삭제합니다. 4. 고급 기술 배우기 : 하위 쿼리 및 창 함수. 5. 디버깅 및 최적화 : 구문 확인, 인덱스 사용, 선택*을 피하고 제한을 사용하십시오.

MySQL은 테이블 구조 및 SQL 쿼리를 통해 구조화 된 데이터를 효율적으로 관리하고 외래 키를 통해 테이블 간 관계를 구현합니다. 1. 테이블을 만들 때 데이터 형식을 정의하고 입력하십시오. 2. 외래 키를 사용하여 테이블 간의 관계를 설정하십시오. 3. 인덱싱 및 쿼리 최적화를 통해 성능을 향상시킵니다. 4. 데이터 보안 및 성능 최적화를 보장하기 위해 데이터베이스를 정기적으로 백업 및 모니터링합니다.

MySQL은 웹 개발에 널리 사용되는 오픈 소스 관계형 데이터베이스 관리 시스템입니다. 주요 기능에는 다음이 포함됩니다. 1. 다른 시나리오에 적합한 InnoDB 및 MyISAM과 같은 여러 스토리지 엔진을 지원합니다. 2.로드 밸런싱 및 데이터 백업을 용이하게하기 위해 마스터 슬레이브 복제 기능을 제공합니다. 3. 쿼리 최적화 및 색인 사용을 통해 쿼리 효율성을 향상시킵니다.

SQL은 MySQL 데이터베이스와 상호 작용하여 데이터 첨가, 삭제, 수정, 검사 및 데이터베이스 설계를 실현하는 데 사용됩니다. 1) SQL은 Select, Insert, Update, Delete 문을 통해 데이터 작업을 수행합니다. 2) 데이터베이스 설계 및 관리에 대한 생성, 변경, 삭제 문을 사용하십시오. 3) 복잡한 쿼리 및 데이터 분석은 SQL을 통해 구현되어 비즈니스 의사 결정 효율성을 향상시킵니다.

MySQL의 기본 작업에는 데이터베이스, 테이블 작성 및 SQL을 사용하여 데이터에서 CRUD 작업을 수행하는 것이 포함됩니다. 1. 데이터베이스 생성 : createAbasemy_first_db; 2. 테이블 만들기 : CreateTableBooks (idintauto_incrementprimarykey, titlevarchar (100) notnull, authorvarchar (100) notnull, published_yearint); 3. 데이터 삽입 : InsertIntobooks (Title, Author, Published_year) VA

웹 응용 프로그램에서 MySQL의 주요 역할은 데이터를 저장하고 관리하는 것입니다. 1. MySQL은 사용자 정보, 제품 카탈로그, 트랜잭션 레코드 및 기타 데이터를 효율적으로 처리합니다. 2. SQL 쿼리를 통해 개발자는 데이터베이스에서 정보를 추출하여 동적 컨텐츠를 생성 할 수 있습니다. 3.mysql은 클라이언트-서버 모델을 기반으로 작동하여 허용 가능한 쿼리 속도를 보장합니다.

MySQL 데이터베이스를 구축하는 단계에는 다음이 포함됩니다. 1. 데이터베이스 및 테이블 작성, 2. 데이터 삽입 및 3. 쿼리를 수행하십시오. 먼저 CreateAbase 및 CreateTable 문을 사용하여 데이터베이스 및 테이블을 작성한 다음 InsertInto 문을 사용하여 데이터를 삽입 한 다음 최종적으로 SELECT 문을 사용하여 데이터를 쿼리하십시오.

MySQL은 사용하기 쉽고 강력하기 때문에 초보자에게 적합합니다. 1.MySQL은 관계형 데이터베이스이며 CRUD 작업에 SQL을 사용합니다. 2. 설치가 간단하고 루트 사용자 비밀번호를 구성해야합니다. 3. 삽입, 업데이트, 삭제 및 선택하여 데이터 작업을 수행하십시오. 4. Orderby, Where and Join은 복잡한 쿼리에 사용될 수 있습니다. 5. 디버깅은 구문을 확인하고 쿼리를 분석하기 위해 설명을 사용해야합니다. 6. 최적화 제안에는 인덱스 사용, 올바른 데이터 유형 선택 및 우수한 프로그래밍 습관이 포함됩니다.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

SecList
SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

드림위버 CS6
시각적 웹 개발 도구

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경
