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

Oracle执行语句历史查询—测试和实施人员必备技能

还是找点事情做吧。这个项目做下来,我发现现场的测试人员普遍都不会前台抓SQL(就是指点击一下前台界面的操作,然后去数据库追查

还是找点事情做吧。这个项目做下来,我发现现场的测试人员普遍都不会前台抓SQL(就是指点击一下前台界面的操作,然后去数据库追查

还是找点事情做吧。这个项目做下来,我发现现场的测试人员普遍都不会前台抓SQL(就是指点击一下前台界面的操作,然后去数据库追查刚刚这个动作 操作了哪些表)。后来和做测试的几个其它朋友聊天,也基本不知道这几个视图,感觉很诧异,这个应该是每一个测试人员,以及实施人员(没参与项目数据库开发,不熟悉每个业务具体操作那些表)常用的技能。因此决定总结下,把这小技巧给大家推荐下。

其实很简单,就两个Oracle 自带的视图:v$sql_bind_capture 和 v$sql.

1、先点击下系统前台操作,然后去数据库查询

select distinct sql_text, sql_id, address

from v$sql

where module = 'JDBC Thin Client' --数据库的链接方式

and last_active_time>sysdate-0.0005 --很短的一个时间,不然太多不好区分

and parsing_schema_name like 'INVENTORY%'; --数据库用户名

2、 通个这个查询我们可以知道,刚刚数据库进行操作的SQL(如果语句很长就得看SQL_FULLTEXT这个字段),如果你还想看详细参数,就得继续了。

select t.NAME, t.VALUE_STRING, t.*

from gv$sql_bind_capture t

where t.address = '0700000916BF5110';

Value_string就是你传进去执行的变量值。很不幸的告诉你时间这样显示不了,但我们有办法啊,,继续下面的查询。

select t.value_string,

t.NAME,

t.datatype_string,

DUMP(t.value_anydata),

ANYDATA.accesstimestamp(t.value_anydata)

from gv$sql_bind_capture t

where address = '000000015E3964A8';

具体我就不解释了。

关于v$sql_bind_capture视图大家得注意下,由于数据库参数配置的不同,这个保存绑定变量的值刷新时间是不同的,隐含参数 _cursor_bind_capture_interval,这个就是控制绑定变量抓取频率的参数,默认值是900(15min)。修改参数值很小,可以快速获取绑定变量的值: alter system set "_cursor_bind_capture_interval"=5 scope=both; 不过这个得根据你数据库的具体情况来设置了。如果你抓取到的参数老是没变化,你就要注意下这个抓取刷新的频率是多高了。

select * from v$parameter t where t.name like '%bind%';

还有一点也需要注意,如果你的数据库是RAC多点集群的话,v$sql_bind_capture这个表的数据并没有存到共享存储区,它是在被你链接的单点数据库上面,所以有时候你可能查不到,这时就得单点登录一个个单点数据库去试运气了。

当你刚刚接触别人的二手代码,或作为一个测试人员、实施人员、数据割接人员,不知道每个业务具体操作的是哪些表时,这两视图这样查询是不是很爽。哈哈

linux

推荐阅读
  • PHP 实现实时汇率查询接口
    本文介绍如何使用PHP构建一个实时汇率查询接口,解决网站因数据源限制而无法获取最新汇率的问题。文章将详细讲解从选择合适的数据源到实现接口的具体步骤。 ... [详细]
  • 本文介绍了如何使用PHP进行SQL Server 2010数据库的分页查询,包括设置每页显示的记录数和当前页码,并通过SQL语句实现数据的分页展示。 ... [详细]
  • 代码生成器实战教程:提升编程效率的利器
    本系列文章旨在通过一系列实践案例,详细介绍如何利用代码生成器提高开发效率。本文将引导您完成从下载安装到实际应用的全过程。 ... [详细]
  • UMPlatForm.NET 5.1 版本数据字典管理功能解析
    本文介绍了 UMPlatForm.NET 5.1 版本中的数据字典管理模块,探讨了该模块如何支持平台的数据共享与管理,以及如何通过用户和角色权限来增强系统的安全性。 ... [详细]
  • 本文探讨了SQLAlchemy ORM框架中如何利用外键和关系(relationship)来建立表间联系,简化复杂的查询操作。通过示例代码详细解释了relationship的定义、使用方法及其与外键的相互作用。 ... [详细]
  • 本文介绍了Android SDK Platform Tools的核心功能及其重要性。作为Android SDK的一个关键组成部分,Platform Tools提供了开发者与Android设备进行交互所需的各种工具。 ... [详细]
  • 本文档提供了详细的MySQL安装步骤,包括解压安装文件、选择安装类型、配置MySQL服务以及设置管理员密码等关键环节,帮助用户顺利完成MySQL的安装。 ... [详细]
  • 本文探讨了HTA(HTML Application)环境中HTML5 IndexedDB的可用性问题,并提供了一种替代方案,即通过使用COM ActiveX对象来实现数据存储功能。 ... [详细]
  • 本文介绍了多种将多行数据合并为单行的方法,包括使用动态SQL、函数、CTE等技术,适用于不同的SQL Server版本。 ... [详细]
  • SQLite是一种轻量级的关系型数据库管理系统,尽管体积小巧,却能支持高达2TB的数据库容量,每个数据库以单个文件形式存储。本文将详细介绍SQLite在Android开发中的应用,包括其数据存储机制、事务处理方式及数据类型的动态特性。 ... [详细]
  • Navicat Premium中MySQL用户管理:创建新用户及高级设置
    本文作为Navicat Premium用户管理系列的第二部分,主要介绍如何创建新的MySQL用户,包括设置基本账户信息、密码策略、账户限制以及SSL配置等。 ... [详细]
  • 帝国cms各数据表有什么用
    CMS教程|帝国CMS帝国cmsCMS教程-帝国CMS精易编程助手源码,ubuntu桥接设置,500错误是tomcat吗,爬虫c原理,php会话包括什么,营销seo关键词优化一般多 ... [详细]
  • 本文介绍了多种Eclipse插件,包括XML Schema Infoset Model (XSD)、Graphical Editing Framework (GEF)、Eclipse Modeling Framework (EMF)等,涵盖了从Web开发到图形界面编辑的多个方面。 ... [详细]
  • 本文介绍如何在SQL Server中利用WITH子句和窗口函数ROW_NUMBER()来查询每个类型下的最新数据行。示例包括表结构、数据插入以及最终的查询语句。 ... [详细]
  • 深入浅出:Hadoop架构详解
    Hadoop作为大数据处理的核心技术,包含了一系列组件如HDFS(分布式文件系统)、YARN(资源管理框架)和MapReduce(并行计算模型)。本文将通过实例解析Hadoop的工作原理及其优势。 ... [详细]
author-avatar
mobiledu2502874233
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有