Oracle数据库常用经典查询

本文收集了常用的数据库查询,需要数据库管理员权限:

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);

持续更新中...

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

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

联系方式:[email protected]

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

时间: 2024-07-31 10:57:24

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

ORACLE数据库常用查询二

ORACLE数据库常用查询 1.查看表空间对应数据文件情况: SQL> SELECT TABLESPACE_NAME,FILE_NAME,BYTES/1024/1024 MB,AUTOEXTENSIBLE FROM DBA_DATA_FILES; TABLESPACE_NAME FILE_NAME MB AUTOEXTENSIBLE ------------------------------ ---------------------------------------------------

Oracle 数据库常用操作语句大全

Oracle 数据库常用操作语句大全 一.Oracle数据库操作 1.根据删除的时间查询出被删除的数据 select * from szdj_work_plan AS OF TIMESTAMP TO_TIMESTAMP('2018-1-19 16:51:37', 'yyyy-mm-dd hh24:mi:ss') where subject='测试一下删除0119' 1.表中唯一的最大的值 select hibernate_sequence.nextval from dual 1.创建数据库 cr

Oracle数据库的经典问题 snapshot too old是什么原因引起的

Oracle数据库的经典问题 snapshot too old是什么原因引起的 ORACLE经典错误求解:ORA-1555错误(Snapshot too old ) - ... 书上说是因为the rollback image need for read consistency has prbably been overwriteten by an active transaction. 我就奇怪了,如果一个transaction占用了一些回滚段,直到它commit前,这些回滚段空间应该被锁定了

ASP.NET操作ORACLE数据库之模糊查询

ASP.NET操作ORACLE数据库之模糊查询 一.ASP.NET MVC利用OracleHelper辅助类操作ORACLE数据库 1 //连接Oracle数据库的连接字符串 2 string connectionString = @"Data Source=(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP) 3 (HOST=localhost) (PORT=1521)))(CONNECT_DATA=(SERVICE_NAME=TestDB)))

Oracle数据库常用Sql语句大全

一,数据控制语句 (DML) 部分 1.INSERT  (往数据表里插入记录的语句) INSERT INTO 表名(字段名1, 字段名2, --) VALUES ( 值1, 值2, --); INSERT INTO 表名(字段名1, 字段名2, --)  SELECT (字段名1, 字段名2, --) FROM 另外的表名; 字符串类型的字段值必须用单引号括起来, 例如: 'GOOD DAY' 如果字段值里包含单引号' 需要进行字符串转换, 我们把它替换成两个单引号''. 字符串类型的字段值超过

Oracle 数据库常用sql语句及知识

<Oracle 数据库> 一.常用sql语句: 1.连接系统管理员账号:conn system/system(安装时口令); 2.创建新账号:create user Leo(账号名) identified by Leo(密码): 3.给新账号授权:grant connect,resource to Leo; 4.从某个账户收权:revoke resource from Leo; 5.连接新账号:conn Leo/Leo; 6.显示当前客户:show user; 7.查看表结构:desc s_e

Oracle数据库之四 简单查询

四.简单查询 ? 简单查询的主要特征就是将一张数据表之中的全部数据行进行显示,而后可以利用 SELECT 子句来控制所需要的输出列. 4.1.基础语法 范例:查询 emp 表中的数据(全部数据查询) SELECT * FROM emp; ? 在取得全部数据后,可以发现某些列上会显示 null 的信息,null 表示的是没有内容,但 null != 0 , null 指的是暂时未知的内容. 简单查询语句语法: SELECT [DISTINCT] * | 列名称[AS][列别名],列名称[AS][列

oracle数据库常用关键字以及写法

数据库常用关键字: create table---创建一个表 创建一个表带表名(列名列的类型,列名列的类型--) create table Z_COURSE(id NUMBER, cour_code VARCHAR2(20), cour_name VARCHAR2(20), p_cour_code VARCHAR2(20));   insert into---插入数据 插入数据 表名(表的列类型) 要插入的值(符合列的类型的数据,有几列就写几条而且要符合列的类型) insert into Z_C

Oracle SQL:经典查询练手第一篇

讨论一些常见的SQL经典查询 使用Oracle的Scott用户 表结构如下: emp表 dept表 工资=薪金+佣金 工资=sal+comm 表中数据如下: emp: dept: 问题列表: 用SQL完成以下问题列表: 列出至少有一个员工的所有部门. 列出薪金比“SMITH”多的所有员工. 列出所有员工的姓名及其直接上级的姓名. 列出受雇日期早于其直接上级的所有员工. 列出部门名称和这些部门的员工信息,同时列出那些没有员工的部门 列出所有“CLERK”(办事员)的姓名及其部门名称. 列出最低薪金