PL/SQL developer 开发小技能 and ash show command PL/SQL EXECUTE 以及注释
##sample test windows 调试存储过程,
总体指导思想使用pl/sql
test windows 调试存储过程,存储过程调试 可以用 run to next exception 按钮,找到绑定变量值,导入SQL 手工执行
#########sample 0
---如何在 PL/SQL Block 端查看执行的SQL.
The SQL statement within the PL/SQL block is actually stored separately, but you cannot see it because:
- every sql statement in a PL/SQL block is stored as capital letters
- every comment and INTO clause are removed
- 因为pl/sql 每个块都是封装的,PL/SQL 块中的每个 sql 语句都存储为大写字母,所以查看PL/SQL 代码可以小写。
- 但是在查询V$SQL 我们应该去掉into 选项,并且要所有字母要大写
How to Determine the SQL_ID of a SQL Statement in a PL/SQL Block
OLUTION
If you have a PL/SQL block such as:
begin
select /* SimpleTest */ sum(sal) into v1 from emp;
end;
/
Then if you try to find the SQL_ID from v$sql then you will see the SQL_ID of the PL/SQL block NOT the SQL itself:
SQL> select sql_id, sql_text from v$sql where sql_text like '%SimpleTest%'; SQL_ID SQL_TEXT
------------- ----------------------------------------------------------------------------------
77hjjr9qgwtzm declare v1 number; begin select /* SimpleTest */ sum(sal) into v1 from emp; end;
The SQL statement within the PL/SQL block is actually stored separately, but you cannot see it because:
- every sql statement in a PL/SQL block is stored as capital letters
- every comment and INTO clause are removed
- 因为pl/sql 每个块都是封装的
- 但是在V$SQL 我们应该去掉into 选项
Note that optimizer hints are preserved.
In other words,
is stored as
In order to find it's SQL_ID you would need to search on something similar to the following:
SQL> select sql_id, sql_text from v$sql where sql_text like '%SUM(SAL)%EMP%'; SQL_ID SQL_TEXT
------------- -------------------------------
5mqhh85sm278a SELECT SUM(SAL) FROM EMP
The SQL_ID can also be determined by using the hash_value from a SQL_TRACE. The hash value can be seen in the raw trace file identified by the "hv=" string.
.................................................
PARSING IN CURSOR #1 len=24 dep=1 uid=54 oct=3 lid=54 tim=1194298465705687 hv=1899044106 ad='997aa660'
SELECT SUM(SAL) FROM EMP
END OF STMT
..................
In this case the hash value is 1899044106. To find the SQL_ID using the hash value use the following select:
SQL> SELECT sql_id, hash_value, SUBSTR(sql_text,1,40) Text
FROM v$sql
WHERE hash_value = &Hash_Value; SQL_ID HASH_VALUE SQL_TEXT
------------- ---------- -------------------------------
5mqhh85sm278a 1899044106 SELECT SUM(SAL) FROM EMP
####sample 1
https://www.askmaclean.com/archives/vsqlcommand-sql-opcodes-and-names.html
ash 报告显示 代表都是存储过程封装好的SQL.
V$SQLCOMMAND SQL opcodes and names
47 PL/SQL EXECUTE
ash 报告显示 代表都是存储过程封装好的SQL. 因此无法通过AWR和ASH 报告看出, 因此需要进一步查看里面的查询 有2个方法, 方法1:使用PL/SQL developer 查看源代码,争取从源代码中找到相关的SQL语句以及表,当然这个比较麻烦,具体可以查看sample 2 方法2:
通过方法1 查找到的表,进一步需要通过V$sql进一步查看, 查找到SQL,在根据执行次数排序,排序越在前的SQL语句就越可能是关键语句。
select * from v$sql where sql_text like '%TRAN_AMT%'
###sample 2
https://blog.csdn.net/sinat_35512702/article/details/80937840
->通过在PLSQL Developer 中查看存储过程源码
https://blog.csdn.net/sinat_35512702/article/details/80937840
->.在Package bobodies 中找到存储过程所在的包名,比如TOOL,右键,选择Edit Spec & Body
->.如下图操作,在存储过程名上按住CTRL键 + 右键双击
1.在Package bobodies 中找到存储过程所在的包名,比如TOOL,右键,选择Edit Spec & Body
2.找到你要查看的存储过程,点击一下
3.如下图操作,在存储过程名上按住CTRL键 + 右键双击
4.该存储过程源码就可以看见了
##导入 excel , 选择最下面的 excel file.

##########sample 3:
https://blog.csdn.net/zjxbllg2008/article/details/82380812
手工查看存储过程的包含的关键字
oracle
##for
select * from all_source t where type = 'PROCEDURE' and text like '%mainacc%'
select * from all_source t where type = 'FUNCTION' and text like '%mainacc%'
select * from all_source t where type = 'PACKAGE BODY' and text like '%mainacc%'
查找存储过程
|
1 |
|
查找函数
|
1 |
|
MSSQL
|
1 2 3 4 |
|
Oracle中,如果关键字是一张表的话,还可以通过表的Referenced by属性找到相关的函数、存储过程和触发器等。
如:

MSSQL类似。
oracle数据库中如何查看已经创建的索引信息
1. 根据表名,查询一张表的索引
|
1 |
|
2. 根据索引号,查询表索引字段
|
1 |
|
3.根据索引名,查询创建索引的语句
|
1 |
|
PS:dbms_metadata.get_ddl还可以得到建表语句,如:
|
1 2 |
|
当然,也可以用pl/sql developer工具来查看相关的表的各种信息。
###########sample 3
注释
pl/sql 13
pl/sql 单行内注释 --
多行注释设置可以自行在pl/sql工具中进行配置 如下
配置——首选项——键配置——(查询comment 关键字) edit/selection/comment(uncomment)
configrure——preference——(User Interface)key Configuration ——(fiter comment key) edit/selection/comment(uncomment)
习惯用什么快捷键就直接输入即可,删除可以用esc键。
具体可参考help 很详细

————————————————
版权声明:本文为CSDN博主「tobeafreefish」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/tobeafreefish/article/details/80018213
PL/SQL developer 开发小技能 and ash show command PL/SQL EXECUTE 以及注释的更多相关文章
- pl/sql developer开发工具的beautifier美化插件
对于存储过程中需要编写大量的sql语句,这必然需要美化语句,使得程序可读性更高. pl/sql developer开发工具自带美化工具,不过美化的时候容易使得语句全部改变成大写格式,这样就需要一个插件 ...
- PL/SQL Developer查詢已經執行過的SQL語句記錄 Ctrl+E
PL/SQL Developer查詢已經執行過的SQL語句記錄 最近提数比较多,没有已存在的脚本信息,就手工写呀... 一次性打开了多个提数脚本文件,结果执行完后把脚本保存好了,但是最后的整理其它脚本 ...
- PL/SQL Developer使用小技巧
1.PL/SQL Developer记住登陆密码 在使用PL/SQL Developer时,为了工作方便希望PL/SQL Developer记住登录Oracle的用户名和密码: ...
- PL/SQL Developer 使用小技巧
1.PL/SQL Developer记住登陆密码 在使用PL/SQL Developer时,为了工作方便希望PL/SQL Developer记住登录Oracle的用户名和密码: 设置方法:tools- ...
- Winfrom 开发小技能
1.放弃进度条.动态进度图片等方式实现用户体验优化方式(主要是优化用户等待体验),建议使用方式? 答:对于From或者Control而言,其提供了Cursor属性设置即可. 例如: this.Curs ...
- PL/SQL Developer 建立远程连接数据库的配置 和安装包+汉化包+注册机
PL/SQL Developer ,主要是讲一下如何配置PL/SQL Developer ,连接Oracle数据库. [知识点] 1.PL/SQL Developer 是什么? PL/SQL Deve ...
- PL/SQL Developer导入导出Oracle数据库方法
前一篇博客介绍了Navicat工具备份Oracle的方法.这篇博客介绍一下使用PL/SQL Developer工具导入导出Oracle数据库的方法. PL/SQL Developer是Oracle数据 ...
- PL/SQL Developer连接本地Oracle 11g 64位数据库
转摘:http://www.cnblogs.com/ymj126/p/3712727.html 用于学习,笔记,以备后用. 1.登录PL/SQL Developer 这里省略Oracle数据库和PL/ ...
- PL/SQL Developer去掉启动时自动弹出的Logon弹出框方法
以前用PL/SQL Developer 7.0版本,最近升级到PL/SQL Developer 11.0版本,但每次启动PL/SQL Developer都会自动弹出Logon窗口,并且选中其中的登录历 ...
随机推荐
- java常用日期类型转换
import java.math.BigDecimal; import java.math.RoundingMode; import java.text.DecimalFormat; import j ...
- netty: 解决粘包拆包: 分隔符DelimiterBasedFrameDecoder,定长消息FixedLengthFrameDecoder
DelimiterBasedFrameDecoder 自定义分隔符 给Server发送多条信息,但是server会讲多条信息合并为一条.这时候我们需要对发生的消息指定分割,让client和server ...
- php获取本地化时间戳函数
在实际的工作中我们还需要经常用到指定某个时间生成. 例如:需要找到昨天到今天此时此刻的注册用户. 那么我们需要做两件事情: 1.得到当前的时间unix时间戳.用time()函数就可以直接搞定大理石平台 ...
- (二)IDEA使用,快捷键
idea的快捷键设置: idea支持使用其他开发工具的快捷键,可以在此设置: idea 默认的本身的快捷键: 常用快捷键 Ctrl + Alt + s 打开设置选项 Alt + Enter 修复提示 ...
- MongoDB bindIp 与 bindIpAll
Linux服务器上安装MongoDB后,允许其它客户端IP访问MongoDB服务器.阿里云服务器需要设置入站规则,可参见使用外网访问阿里云服务器ZooKeeper 1.允许所有地址访问 NOTE:ne ...
- js文件夹上传下载组件
核心原理: 该项目核心就是文件分块上传.前后端要高度配合,需要双方约定好一些数据,才能完成大文件分块,我们在项目中要重点解决的以下问题. * 如何分片: * 如何合成一个文件: * 中断了从哪个分片开 ...
- 在Ubuntu 或 Debian 系统环境安装MYSQL数据库
一.第一步下载myslq安装程序 sudo apt-get install mysql-server mysql-client apt-get程序会自动下载安装最新的mysql版本.在安装的最后,它会 ...
- C语言for 循环 9*9 实现九九乘法表
#include <stdio.h> int main(void) { //for循环实现9*9乘法表 /* 1*1=1 1*2=2 2*2=4 1*3=3 2*3=6 3*3=9 */ ...
- Problem 5 素数筛法+并查集
$des$ 给定一个长度为 $n$ 的正整数序列 ${a_i }$.将 ${1,2,...,n}$ 划分成两个非空集合 $S.T$,使得 $gcd(\prod_{i \in S} a_i, \prod ...
- Problem 1 bfs+set
$des$ 小G有一个长度为 $n$ 的 01 串 T ,其中只有 $T_S = 1$,其余位置都是 $0$.现在小G可以进行若干次以下操作:选择一个长度为 $K$ 的连续子串(K是给定的常数),翻转 ...