Oracle 执行语句历史查询—测试和实施人员必备技能
还是找点事情做吧。这个项目做下来,我发现现场的测试人员普遍都不会前台抓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这个表的数据并没有存到共享存储区,它是在被你链接的单点数据库上面,所以有时候你可能查不到,这时就得单点登录一个个单点数据库去试运气了。
当你刚刚接触别人的二手代码,或作为一个测试人员、实施人员、数据割接人员,不知道每个业务具体操作的是哪些表时,这两视图这样查询是不是很爽。哈哈

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











この記事では、DockerのMySQLメモリ使用量を最適化することを調査します。 監視手法(Docker統計、パフォーマンススキーマ、外部ツール)および構成戦略について説明します。 これらには、Dockerメモリの制限、スワッピング、およびcgroupsが含まれます

この記事では、MySQLの「共有ライブラリを開くことができない」エラーについて説明します。 この問題は、必要な共有ライブラリ(.so/.dllファイル)を見つけることができないMySQLの障害に起因しています。ソリューションには、システムのパッケージMを介してライブラリのインストールを確認することが含まれます。

この記事では、MySQLのAlter Tableステートメントを使用して、列の追加/ドロップ、テーブル/列の名前の変更、列データ型の変更など、テーブルを変更することについて説明します。

この記事では、PHPMyAdminの有無にかかわらず、LinuxにMySQLを直接インストールするのとPodmanコンテナを使用します。 それは、各方法のインストール手順を詳述し、孤立、携帯性、再現性におけるポッドマンの利点を強調しますが、

この記事では、自己完結型のサーバーレスリレーショナルデータベースであるSQLiteの包括的な概要を説明します。 SQLiteの利点(シンプルさ、移植性、使いやすさ)と短所(同時性の制限、スケーラビリティの課題)を詳しく説明しています。 c

このガイドは、HomeBrewを使用してMacOSに複数のMySQLバージョンをインストールおよび管理することを示しています。 Homebrewを使用して設置を分離し、紛争を防ぐことを強調しています。 この記事では、インストール、開始/停止サービス、および最高のPRAを詳述しています

記事では、証明書の生成と検証を含むMySQL用のSSL/TLS暗号化の構成について説明します。主な問題は、セルフ署名証明書のセキュリティへの影響を使用することです。[文字カウント:159]

記事では、MySQLワークベンチやPHPMyAdminなどの人気のあるMySQL GUIツールについて説明し、初心者と上級ユーザーの機能と適合性を比較します。[159文字]
