本文收集了经常使用的数据库查询。须要数据库管理员权限:

1. 查询暂时表空间使用情况

SELECT TABLESPACE_NAME,
TABLESPACE_SIZE / 1024 / 1024 TABLESPACE_SIZE_MB,
ALLOCATED_SPACE / 1024 / 1024 ALLOCATED_SPACE_MB,
FREE_SPACE / 1024 / 1024 FREE_SPACE_MB,
TO_CHAR((1 - FREE_SPACE / TABLESPACE_SIZE) * 100, '900.00') PERCENTAGE_USED
FROM DBA_TEMP_FREE_SPACE
;

2. 查询使用TEMP表空间的语句的SID, SERIAL#:

SELECT   B.TABLESPACE, B.SEGFILE#, B.SEGBLK#, ROUND (  (  ( B.BLOCKS * P.VALUE ) / 1024 / 1024 / 1024 ), 2 ) SIZE_GB
, A.SID, A.SERIAL#, A.USERNAME, A.OSUSER, A.PROGRAM, A.STATUS
FROM V$SESSION A, V$SORT_USAGE B, V$PROCESS C, V$PARAMETER P
WHERE P.NAME = 'db_block_size'
AND A.SADDR = B.SESSION_ADDR
AND A.PADDR = C.ADDR
ORDER BY SIZE_GB DESC;

3. 依据上面查询 出的SERIAL#,查询出相应的语句:

SELECT S.SID, S.SERIAL#, T.SQL_FULLTEXT,T.SQL_ID,S.SQL_HASH_VALUE,T.HASH_VALUE
FROM V$SESSION S, V$SQL T
WHERE S.SQL_ADDRESS = T.ADDRESS
AND S.SQL_HASH_VALUE = T.HASH_VALUE
AND S.SERIAL# = '&SERIAL#';

4. 查询表空间的使用情况:

SELECT 	TSU.TABLESPACE_NAME, CEIL(TSU.USED_GB) "used GB" --15467
, DECODE(CEIL(TSF.FREE_GB), NULL,0,CEIL(TSF.FREE_GB)) "free GB"
, DECODE(100 - CEIL(TSF.FREE_GB/TSU.USED_GB*100), NULL, 100
, 100 - CEIL(TSF.FREE_GB/TSU.USED_GB*100)) "% used"
FROM (SELECT TABLESPACE_NAME, SUM(BYTES)/1024/1024/1024 USED_GB
FROM DBA_DATA_FILES
GROUP BY TABLESPACE_NAME
UNION ALL
SELECT TABLESPACE_NAME || ' **TEMP**',SUM(BYTES)/1024/1024/1024 USED_GB
FROM DBA_TEMP_FILES
GROUP BY TABLESPACE_NAME
) TSU
, (SELECT TABLESPACE_NAME, SUM(BYTES)/1024/1024/1024 FREE_GB
FROM DBA_FREE_SPACE
GROUP BY TABLESPACE_NAME
) TSF
WHERE TSU.TABLESPACE_NAME = TSF.TABLESPACE_NAME (+)
AND ( TSF.TABLESPACE_NAME IN ('&tablespace_name1', '&tablespace_name1') );

5. 查询执行时间长的Session:

SELECT *
FROM
(SELECT *
FROM
(SELECT VP.START_TIME "Start Time",ROUND((VP.LAST_UPDATE_TIME - VP.START_TIME)*60*24*60) ELAPSED,VP.MESSAGE "Message",
DECODE (VP.TOTALWORK, 0, 0, ROUND (100 * VP.SOFAR / VP.TOTALWORK, 2)) "Percent", VP.TIME_REMAINING||' sec' REMAINING
FROM V$SESSION_LONGOPS VP
WHERE VP.SID = &session_id --实际要替换的參数
)
ORDER BY 1 DESC
);

6. 查询数据库表的大小

SELECT SEGMENT_NAME, SUM(BYTES) / 1024 / 1024 / 1024 GB
FROM DBA_SEGMENTS
WHERE SEGMENT_NAME = '&table_name' <span style="font-family: Arial, Helvetica, sans-serif;">--实际要替换的參数</span>
GROUP BY SEGMENT_NAME;

7. 查询数据库表的依赖:

SELECT * FROM DBA_DEPENDENCIES WHERE REFERENCED_NAME='&object_name';--输入对象名称

8. 输出创建表的语句

DECLARE
V_STR LONG;
CURSOR CUR
IS
SELECT COLUMN_NAME||' '||DECODE(DATA_TYPE, 'NUMBER', DECODE(NULLIF(DATA_LENGTH, 22), NULL, DATA_TYPE, DATA_TYPE||'('||DATA_LENGTH||')'),
'DATE', DATA_TYPE,
DATA_TYPE||'('||DATA_LENGTH||')'
)||',' COL
FROM DBA_TAB_COLS
WHERE TABLE_NAME='&SOURCE_TABLE_NAME'
AND OWNER='&SOURCE_TABLE_OWNER'
ORDER BY COLUMN_NAME ASC;
BEGIN
FOR REC IN CUR LOOP
V_STR:=V_STR||REC.COL||CHR(10);
END LOOP;
V_STR:='CREATE TABLE'||' &TABLE_NAME'||' '||'('||CHR(10)||V_STR||CHR(10)||');';
DBMS_OUTPUT.PUT_LINE(V_STR);
END;

9. 查询表结构

SELECT DBMS_METADATA.GET_DDL('TABLE','&table_name','&schema') FROM DUAL;--替换表名与表所在的schema

10. 查询数据库的字符集

SELECT * FROM NLS_DATABASE_PARAMETERS;

11. 查询 数据库用到的database link:

SELECT * FROM DBA_DB_LINKS WHERE DB_LINK='&db_link';

12. 查询数据表上的索引

select * from dba_indexes where owner='&owner' and table_name='&table_name';

13. 查询数据表用到的索引列

select * from dba_ind_columns where index_owner='&owner' and table_name='&table_name';

14. 查询数据表里的存储过程/函数/自己定义类型/触发器/包

select * from dba_source
where onwer='&owner'
and type='&type';

15. 查询约束

select * from dba_constraints;
select * from all_constraints;
select * from user_constraints;

16. 查询同义词

select * from dba_synonyms;
select * from all_synonyms;
select * from user_synonyms;

17. 查询出发器

select * from dba_triggers;
select * from all_triggers;
select * from user_triggers;

18. 查询视图

select * from dba_views;
select * from all_views;
select * from user_views;

19. 查询序列

select * from dba_sequences;
select * from all_sequences;
select * from user_sequences;

20. 查询物化视图

select * from DBA_MVIEWS;
select * from ALL_MVIEWS;
select * from USER_MVIEWS;

21. 查询数据库对象

select * from DBA_OBJECTS;
select * from ALL_OBJECTS;
select * from USER_OBJECTS;

22. 查询存储过程

select * from DBA_PROCEDURES;
select * from ALL_PROCEDURES;
select * from USER_PROCEDURES;

23. 查询数据库表

select * from DBA_TABLES;
select * from ALL_TABLES;
select * from USER_TABLES;

24. 查询数据库表的列

select * from DBA_TAB_COLUMNS;
select * from ALL_TAB_COLUMNS;
select * from USER_TAB_COLUMNS;
select * from DBA_TAB_COLS;
select * from ALL_TAB_COLS;
select * from USER_TAB_COLS;

25. 查询数据库表列的备注

select * from DBA_TAB_COMMENTS;
select * from ALL_TAB_COMMENTS;
select * from USER_TAB_COMMENTS;

26. 查看查询的运行计划

explain plan for select * from dict;
select * from table(dbms_xplan.display);

持续更新中...

----------------------------------------------------------------------------------------------------------------------------------------------------

假设您们在尝试的过程中遇到什么问题或者我的代码有错误的地方。请给予指正,很感谢!

联系方式:david.louis.tian@outlook.com

版权@:转载请标明出处!

Oracle数据库经常使用经典查询的更多相关文章

  1. Oracle数据库之七 多表查询

    七.多表查询 ​ 对于查询在之前已经学过了简单查询.限定查询.查询排序,这些都属于 SQL 的标准语句,而上一章的单行函数,主要功能是为了弥补查询的不足. ​ 而从多表查询开始就正式进入到了复杂查询部 ...

  2. SQLSERVER 创建对Oracle数据库的DBlink以及查询使用

    1. 与针对oracle数据库一样, 在sqlserver中创建对oracle数据库的dblink 安全性上面也进行定义(貌似不需要跟访问字符串只需要填一个即可) 发现有的版本改注册表不管用 还得修改 ...

  3. Oracle 数据库基础:数据查询与操作

    SELECT uname FROM TUser WHERE uname=‘admin’ SELECT 字段名列表 FROM 表名 WHERE 条件; 在Oracle数据库中,对象是属于模式的,每个账户 ...

  4. 007.Oracle数据库 , 使用%进行模糊查询

    /*Oracle数据库查询日期在两者之间*/ SELECT PKID, OCCUR_DATE, ATA FROM LM_FAULT WHERE ( ( OCCUR_DATE >= to_date ...

  5. Oracle数据库order by排序查询分页比不分页还慢问题解决办法

    简单说下问题,有一个JDBC的查询SQL,分页查询语句中有一个排序order by create_time,理论上来说JDBC查询已经是比较底层的技术了,没有像Hibernate.MyBatis那样又 ...

  6. Oracle数据库之单表查询

    接着上一篇的分享,今天主要给大家分享的是关于数据中的单表查询,单表查询很基础,也很重要,但是任何一个初学者必须要掌握的姿势,单表查询就是对单个表进行操作,查询我们想要的数据.单表查询里面的内容也是比较 ...

  7. ORACLE数据库存储空间使用情况查询

    使用系统sys或者dba权限的账户创建视图如下: 1. 主要从数据库的表dba_data_files,dba_segments两张表中获取.2. 默认数据库保存的是byte单位,转换关系如下: 102 ...

  8. oracle数据库使用之数据查询入门

    1.在查询过程中使用算术表达式对数据进行运算 student表结构如下: 最后一项salary表示每个人的月薪,我现在想查询每个人的年薪: 2.使用nvl函数处理null值,向表中插入一条数据,该数据 ...

  9. Oracle数据库按属性成绩查询

    create or replace function bb return nvarchar2as-----------自定义游标类型type class_student is record( snam ...

随机推荐

  1. pl/sql sql窗口允许输出和允许变量替换

    pl/sql sql窗口允许输出和允许变量替换 允许输出:类似在命令窗口中输入的 setserveroutput on; 允许变量替换:如果点击了这个,类似于执行 set define off命令 在 ...

  2. hdu 4717 The Moving Points(三分)

    http://acm.hdu.edu.cn/showproblem.php?pid=4717 大致题意:给出每一个点的坐标以及每一个点移动的速度和方向. 问在那一时刻点集中最远的距离在全部时刻的最远距 ...

  3. 《大话操作系统——做坚实的project实践派》(2)

      <大话操作系统--做坚实的project实践派>(2) 

  4. 剑指offer面试题14(Java版):调整数组顺序使奇数位于偶数的前面

    题目:输入一个整数数组.实现一个函数来调整该数组中数字的顺序.使得全部奇数位于数组的前半部分.全部偶数位于数组的后半部分. 1.基本实现: 假设不考虑时间复杂度,最简单的思路应该是从头扫描这个数组,每 ...

  5. DNS反射放大攻击分析——DNS反射放大攻击主要是利用DNS回复包比请求包大的特点,放大流量,伪造请求包的源IP地址为受害者IP,将应答包的流量引入受害的服务器

    DNS反射放大攻击分析 摘自:http://www.shaojike.com/2016/08/19/DNS%E6%94%BE%E5%A4%A7%E6%94%BB%E5%87%BB%E7%AE%80%E ...

  6. spark Bisecting k-means(二分K均值算法)

    Bisecting k-means(二分K均值算法) 二分k均值(bisecting k-means)是一种层次聚类方法,算法的主要思想是:首先将所有点作为一个簇,然后将该簇一分为二.之后选择能最大程 ...

  7. Modules:手机号码验证

    ylbtech-Modules:手机号码验证 手机号码验证,文档以JFB项目架构为原型,介绍实现原理,如何调用和应用实例. 架构包括5个主要模块:Basebase,Base,Service,Api和W ...

  8. 在nodejs使用Redis缓存和查询数据及Session持久化(Express)

    在nodejs使用Redis缓存和查询数据及Session持久化(Express) https://segmentfault.com/a/1190000002488971

  9. jQuery插件开发的两种方法

    1 类级别 类级别你可以理解为拓展jquery类,最明显的例子是$.ajax(...),相当于静态方法. 开发扩展其方法时使用$.extend方法,即jQuery.extend(object); $. ...

  10. mysql授予IP远程访问访问语句

    mysql -u root -p; GRANT ALL PRIVILEGES ON *.* TO '用户名'@'你的IP地址' IDENTIFIED BY '密码' WITH GRANT OPTION ...