wxyfj 发表于 2018-10-23 11:27:23

v$sql、v$sqlarea、v$sqltext

  这三个视图都可以用于查询共享池中已经解析过的SQL语句及其相关信息。
  V$SQL中列出了共享SQL区中所有语句的信息,它不包含GROUP BY字句,并且为每一条SQL语句中单独存放一条记录;
  V$SQLAREA中一条记录显示了一条共享SQL区中的统计信息。它提供了有在内存中、解析过的和准备运行的SQL语句的统计信息;
  V$SQLTEXT包含了库缓存中所有共享游标对应的SQL语句。它将SQL语句分片显示。
  下面介绍一下常用的V$SQLAREA的结构:
  SQL_TEXT 游标中SQL语句的前1000个字符。
  SHARABLE_MEM 被游标占用的共享内存大小。如果存在多个子游标,则包含所有子游标占用的共享内存大小。
  PERSISTENT_MEM   用于一个打开这条语句的游标的生命过程中的固定内存大小。如果存在多个子游标,则包含所有子游标生命过程中的固定内存大小。
  RUNTIME_MEM一个打开这条语句的游标的执行过程中的固定内存大小。如果存在多个子游标,则包含所有子游标执行过程中的固定内存大小。
  SORTS    所有子游标执行语句所导致的排序次数。
  VERSION_COUNT    缓存中关联这条语句的子游标数。
  OPEN_VERSIONS    打开语句的子游标数。
  USERS_OPENING    打开这些子游标的用户数。
  FETCHES SQL语句的fetch数。
  EXECUTIONS   所有子游标的执行这条语句次数。
  USERS_EXECUTING通过子游标执行这条语句的用户数。
  LOADS    语句被载入和重载入的次数
  FIRST_LOAD_TIME语句被第一次载入的时间戳。
  INVALIDATIONS    所以子游标的非法次数。
  PARSE_CALLS所有子游标对这条语句的解析调用次数。
  DISK_READS   所有子游标运行这条语句导致的读磁盘次数。
  BUFFER_GETS所有子游标运行这条语句导致的读内存次数。
  ROWS_PROCESSED   这条语句处理的总记录行数。
  PARSING_USER_ID第一次解析这条语句的用户的ID。
  ADDRESS指向语句的地址
  HASH_VALUE   这条语句在library cache中hash值。
  MODULE_HASH模块的Hash值
  ACTION_HASH动作的Hash值
  CHILD_LATCH为了包含此游标的子latch数。
  查看当前会话所执行的语句以及会话相关信息:
  SQL> select a.sid||'.'||a.SERIAL#, a.username, a.TERMINAL, a.program, s.sql_text
  2   from v$session a, v$sqlarea s
  3   where a.sql_address = s.address(+)
  4   and a.sql_hash_value = s.hash_value(+)
  5   order by a.username, a.sid;
  ·      v$sql_plan
  视图V$SQL_PLAN包含了library cache中所有游标的执行计划。通过结合v$sqlarea可以查出library cache中所有语句的查询计划。先从v$sqlarea中得到语句的地址,然后在由v$sql_plan查出它的查询计划:
  SQL> select lpad(' ', 2*(level-1))||operation "Operation",options "Options",
  2          decode(to_char(id), '0', 'Cost='||nvl(to_char(position), 'n/a'), object_name) "Object Name", substr(optimizer, 1, 6) "Optimizer"
  3    from v$sql_plan a
  4   start with address = 'C0000000FCCDEDA0'

  5   and>
  6   connect by prior>  7   and prior a.address = a.address
  8   and prior a.hash_value = a.hash_value;
  Operation       Options      Object Name      Optimizer
  ---------------- --------------- ----------------- ---------
  SELECT STATEMENT                Cost=0         CHOOSE
  NESTED LOOPS
  INDEX         RANGE SCAN            CSS_BL_CNTR_IDX1      ANALYZ
  INDEX         RANGE SCAN            CSS_BKG_BL_ASSN_UQ1   ANALYZ

页: [1]
查看完整版本: v$sql、v$sqlarea、v$sqltext