Oracle常用SQL命令

1. Oracle查看表空间使用率(包含临时表空间)  

set pagesize 500
set lin 120
col TABLESPACE_NAME for a30
col SUM_SPACE(M) for a15
col SUM_BLOCKS for a35
col USED_SPACE(M) for a15
col USED_RATE(%) for a15
col FREE_SPACE(M) for a15
SELECT D.TABLESPACE_NAME,  
       SPACE || 'M' "SUM_SPACE(M)",  
       SPACE - NVL (FREE_SPACE, 0) || 'M' "USED_SPACE(M)",  
       ROUND ( (1 - NVL (FREE_SPACE, 0) / SPACE) * 100, 2) || '%'  
          "USED_RATE(%)",  
       FREE_SPACE || 'M' "FREE_SPACE(M)"  
  FROM (  SELECT TABLESPACE_NAME,  
                 ROUND (SUM (BYTES) / (1024 * 1024), 2) SPACE,  
                 SUM (BLOCKS) BLOCKS  
            FROM DBA_DATA_FILES  
        GROUP BY TABLESPACE_NAME) D,  
       (  SELECT TABLESPACE_NAME,  
                 ROUND (SUM (BYTES) / (1024 * 1024), 2) FREE_SPACE  
            FROM DBA_FREE_SPACE  
        GROUP BY TABLESPACE_NAME) F  
 WHERE D.TABLESPACE_NAME = F.TABLESPACE_NAME(+)  
UNION ALL                                                          
SELECT D.TABLESPACE_NAME,  
       SPACE || 'M' "SUM_SPACE(M)",  
       USED_SPACE || 'M' "USED_SPACE(M)",  
       ROUND (NVL (USED_SPACE, 0) / SPACE * 100, 2) || '%' "USED_RATE(%)",  
       NVL (FREE_SPACE, 0) || 'M' "FREE_SPACE(M)"  
  FROM (  SELECT TABLESPACE_NAME,  
                 ROUND (SUM (BYTES) / (1024 * 1024), 2) SPACE,  
                 SUM (BLOCKS) BLOCKS  
            FROM DBA_TEMP_FILES  
        GROUP BY TABLESPACE_NAME) D,  
       (  SELECT TABLESPACE_NAME,  
                 ROUND (SUM (BYTES_USED) / (1024 * 1024), 2) USED_SPACE,  
                 ROUND (SUM (BYTES_FREE) / (1024 * 1024), 2) FREE_SPACE  
            FROM V$TEMP_SPACE_HEADER  
        GROUP BY TABLESPACE_NAME) F  
 WHERE D.TABLESPACE_NAME = F.TABLESPACE_NAME(+)  
ORDER BY 1;  

  

2. 查看表空间的名字和所属文件

 

set line 200;
col tablespace_name format a30;
col file_id format 999;
col file_name format a70;
col total_space format 999999;
 
select tablespace_name, file_id, file_name,
round(bytes/(1024*1024),0) total_space
from dba_data_files
order by tablespace_name;
 
##查看用户和默认的表空间
select username,default_tablespace from dba_users order by 1;

##查看物理文件使用率
select   b.file_name 物理文件名,
         b.tablespace_name 表空间,
         b.bytes / 1024 / 1024 大小M,
         (b.bytes - sum(nvl(a.bytes, 0))) / 1024 / 1024 已使用M,
         substr((b.bytes - sum(nvl(a.bytes, 0))) / (b.bytes) * 100, 1, 5) 利用率   from dba_free_space a,
       dba_data_files b   where a.file_id = b.file_id   group by b.tablespace_name,
       b.file_name,
       b.bytes   order by b.tablespace_name;

 

 

 

 3. 将一个用户的所有对象授权给另一个用户:

--首先是CPR账号
--授权表上的读写权限
select 'grant all on ' || owner || '.' || table_name || ' to hisuser;'
  from dba_tables
 where owner = 'CPR';

--授权视图上的读写权限
select 'grant all on ' || owner || '.' || view_name || ' to hisuser;'
  from dba_views
 where owner = 'CPR';

--授权函数和存储过程的读写权限
select 'grant execute on ' || owner || '.' || name || ' to hisuser;'
  from dba_source
 where owner = 'CPR'
   and type in ('PROCEDURE',
                'FUNCTION',
                'PACKAGE',
                'PACKAGE BODY',
                'TYPE BODY',
                'TRIGGER',
                'TYPE');

--授权序列的读写权限
select 'grant all on ' || sequence_owner || '.' || sequence_name ||
       ' to hisuser;'
  from dba_sequences
 where sequence_owner = 'CPR';

--创建同义词
select 'create or replace public synonym ' || synonym_name || ' for ' ||
       table_owner || '.' || table_name || ' ;'
  from dba_synonyms
 where table_owner = 'CPR';
select 'create or replace public synonym ' || view_name || ' for ' || owner || '.' ||
       view_name || ' ;'
  from dba_views
 where owner = 'CPR'
   and (owner NOT LIKE '%$%' OR view_name NOT LIKE '%$%');

--然后是system账号
--授权表上的读写权限
select 'grant all on ' || owner || '.' || table_name || ' to hisuser;'
  from dba_tables
 where owner = 'SYSTEM'
   and table_name NOT LIKE '%$%';

--授权视图上的读写权限
select 'grant all on ' || owner || '.' || view_name || ' to hisuser;'
  from dba_views
 where owner = 'SYS';

--授权函数和存储过程的读写权限
select DISTINCT 'grant execute on ' || owner || '.' || name ||
                ' to hisuser;'
  from dba_source
 where owner = 'SYS'
   and type in ('PROCEDURE',
                'FUNCTION',
                'PACKAGE',
                'PACKAGE BODY',
                'TYPE BODY',
                'TRIGGER',
                'TYPE')
   AND name NOT LIKE '%$%';

--授权序列的读写权限
select 'grant all on ' || sequence_owner || '.' || sequence_name ||
       ' to hisuser;'
  from dba_sequences
 where sequence_owner = 'SYSTEM'
   AND sequence_name NOT LIKE '%$%';

--创建同义词
select 'create or replace public synonym ' || synonym_name || ' for ' ||
       table_owner || '.' || table_name || ' ;'
  from dba_synonyms
 where table_owner = 'SYS'
   and synonym_name NOT LIKE '%$%';

select 'create or replace public synonym ' || view_name || ' for ' || owner || '.' ||
       view_name || ' ;'
  from dba_views
 where owner = 'SYS'
   and (owner NOT LIKE '%$%' OR view_name NOT LIKE '%$%');

 4.扩大表空间

--1.增加数据文件
ALTER TABLESPACE game ADD DATAFILE '/oracle/oradata/db/GAME02.dbf' SIZE 1000M;

--2.手动增加数据文件尺寸
ALTER DATABASE DATAFILE '/oracle/oradata/db/GAME.dbf' RESIZE 4000M;

--RAC自动管理的表空间增加数据文件的方法:
数据文件:
alter tablespace TEMP add datafile size 30g;
临时文件:
alter tablespace temp add tempfile size 30g;

5. 通过RMAN删除过期的归档日志

DELETE  force noprompt ARCHIVELOG ALL COMPLETED BEFORE 'SYSDATE-5';

 6. 密码默认180天过期修改:

--1
SELECT  *  FROM  dba_profiles  WHERE  profile='DEFAULT'  AND  resource_name='PASSWORD_LIFE_TIME';
--180 天到期
 
更改密码为无期
--2
ALTER  PROFILE  DEFAULT  LIMIT  PASSWORD_LIFE_TIME  UNLIMITED;

7.ASM磁盘剩余空间查看:

select group_number,name,total_mb,free_mb from v$asm_diskgroup;

8.历史归档日志容量查看:

select trunc(COMPLETION_TIME) TIME, SUM(BLOCKS * BLOCK_SIZE)/1024/1024 SIZE_MB from V$ARCHIVED_LOG group by trunc (COMPLETION_TIME) order by 1;

09.验证RMAN备份信息:

SELECT START_TIME,
      END_TIME,
      OUTPUT_DEVICE_TYPE,
      STATUS,
      ELAPSED_SECONDS,
      COMPRESSION_RATIO,
      INPUT_BYTES_DISPLAY,
      OUTPUT_BYTES_DISPLAY
FROM V$RMAN_BACKUP_JOB_DETAILS
ORDER BY START_TIME DESC ;

10. Oracle 杀掉当前用户的进程

select ' alter system kill session '''|| sid ||','||serial# || ''';' from v$SESSION where username='UserName';

 

11. Oracle归档日志清理脚本 

##脚本方法1:
#!/bin/bash
if [ -f ~/.bash_profile ]; then
    . ~/.bash_profile
fi

#set env
echo "Oracle home:"$ORACLE_HOME
echo "Oracle SID:"$ORACLE_SID

$ORACLE_HOME/bin/rman target sys/SysPassword@Oracle_SID log=/tmp/rman.log <<EOF
crosscheck archivelog all;
delete noprompt expired archivelog all;
delete noprompt archivelog all completed before 'sysdate - 5';
exit;
EOF


####脚本方法2:
#!/bin/bash
if [ -f ~/.bash_profile ]; then
    . ~/.bash_profile
fi

#set env
echo "Oracle home:"$ORACLE_HOME
echo "Oracle SID:"$ORACLE_SID

$ORACLE_HOME/bin/rman log=/tmp/rman.log <<EOF       
connect target sys/SysPassword@Oracle_SID
run{
crosscheck archivelog all;    
delete noprompt expired archivelog all;    
delete noprompt archivelog all completed before 'sysdate - 5';    
}  


##设置定时任务:
crontab -l
0 1 * * * /home/oracle/scripts/clear_archivelog.sh > /tmp/clear_archivelog.log

##备注:
1. 必须在Oracle用户下编辑执行脚本
2. 必须给/home/oracle/scripts/clear_archivelog.sh执行权限
3. 必须验证

 

 12. Oracle锁管理

 

##1. 确定锁进程的sid
SELECT
    t2.username,
    t2.sid,
    t2.serial#,
    t2.logon_time
FROM
    v$locked_object t1,
    v$session t2
WHERE
    t1.session_id = t2.sid
ORDER BY
    t2.logon_time;
    
##2. 通过sid获得它的sql,看是哪一条sql导致锁的占用    
SELECT
    sql_text
FROM
    v$sql t1,
    v$session t2
WHERE
    t1.address = t2.sql_address
    AND t2.sid = & sid; --&sid 就是上一条sql中查到的sid

##3.1 如有记录则表示有lock,记录下SID和serial# ,执行下面的sql,即可解除锁    
ALTER system kill SESSION 'SID,serial#';


##3.2 批量删除脚本:
SELECT
    'alter system kill session ''' || sid || ',' || serial# || ''';' "deadlock"
FROM
    v$session
WHERE
    sid IN (
    SELECT
        sid
    FROM
        v$lock
    WHERE
        block = 1);
##注意:应当注意对于 sid 在 100 以下的应当谨慎,可能该进程对应某个application,如对应某个事务,可以 kill.

 

13. 长时间运行SQL语句处理:

##Oracle中查询某个sql是哪个用户发出可用如下语句:
SELECT
    a.sql_text,
    b.username
FROM
    v$sql a,
    v$session b
WHERE
    a.hash_value = b.sql_hash_value;
    
    

##查询执行时间长的SQL语句
SELECT
    sid,
    serial#,
    sql_text,
    executions
FROM
    v$sql
JOIN v$session ON
    v$sql.sql_id = v$session.sql_id
WHERE
    cpu_time > 20000;
    
##杀掉SQL语句:
alter system kill session 'sid,serial#';


##自己编辑的SQL语句,待完善
SELECT
    b.username ,
    b.sid,
    b.serial#,
    a.sql_text
FROM
    v$sql a,
    v$session b
WHERE
    (a.sql_id = b.sql_id)
    AND ( a.hash_value = b.sql_hash_value)
    AND cpu_time > 20000
ORDER BY
    1;

--通过sql_id查找sid,serial#

select sid,serial#,username ,osuser from v$session where (sql_hash_value,sql_address)=(select hash_value,address from v$sqlarea where sql_id='f7285r39svxr6' );

 14.  使用触发器实现记录oracle用户登录失败信息到alert.log日志文件

转载自:https://www.cnblogs.com/xinxin1994/p/6078107.html


CREATE OR REPLACE TRIGGER logon_denied_to_alert
  AFTER servererror ON DATABASE
DECLARE
  message   VARCHAR2(168);
  ip        VARCHAR2(15);
  v_os_user VARCHAR2(80);
  v_module  VARCHAR2(50);
  v_action  VARCHAR2(50);
  v_pid     VARCHAR2(10);
  v_sid     NUMBER;
  v_program VARCHAR2(48);
BEGIN
  IF (ora_is_servererror(1017)) THEN
  
    -- get ip FOR remote connections :
    IF upper(sys_context('userenv', 'network_protocol')) = 'TCP' THEN
      ip := sys_context('userenv', 'ip_address');
    END IF;
  
    SELECT sid INTO v_sid FROM sys.v_$mystat WHERE rownum < 2;
    SELECT p.spid, v.program
      INTO v_pid, v_program
      FROM v$process p, v$session v
     WHERE p.addr = v.paddr
       AND v.sid = v_sid;
  
    v_os_user := sys_context('userenv', 'os_user');
    dbms_application_info.read_module(v_module, v_action);
  
    message := to_char(SYSDATE, 'YYYYMMDD HH24MISS') ||
               ' logon denied from ' || nvl(ip, 'localhost') || ' ' ||
               v_pid || ' ' || v_os_user || ' with ' || v_program || '' ||
               v_module || ' ' || v_action;
  
    sys.dbms_system.ksdwrt(2, message);
  
  END IF;
END;

 

15.  解决Oracle 11gR2 空闲连接过多,导致连接数满的问题

 

转载自:http://blog.itpub.net/28998293/viewspace-1153969/

CREATE
PROFILE KILLIDLE LIMIT IDLE_TIME 30; SELECT * FROM dba_profiles WHERE PROFILE='KILLIDLE'; ALTER USER TEST_USER PROFILE KILLIDLE; SELECT username,PROFILE FROM dba_users WHERE username='TEST_USER'; ALTER SYSTEM SET resource_limit=TRUE; CREATE OR REPLACE PROCEDURE sp_kill_idlesession /********************************** 清除idle超时的会话进程 **********************************/ AS CURSOR c_kill_sqls IS SELECT 'alter system kill session ''' || s.sid || ',' || s.SERIAL# || ''' immediate' sqlstr FROM v$session s WHERE s.STATUS = 'SNIPED'; BEGIN FOR v_sql IN c_kill_sqls LOOP EXECUTE IMMEDIATE v_sql.sqlstr; END LOOP; END; --添加JOB,定时清理过期会话 DECLARE jobnum NUMBER := 661; BEGIN dbms_job.submit(job => jobnum, what => 'sp_kill_idlesession;', next_date => to_date('30-04-2014 18:00:00', 'dd-mm-yyyy hh24:mi:ss'), INTERVAL => 'SYSDATE + 1/144'); COMMIT; END; --如果30分钟过期时间太短,对数据库访问性能产生了影响,可以调整 ALTER PROFILE KILLIDLE LIMIT IDLE_TIME 30;

 

转载于:https://www.cnblogs.com/zhuntidaoren/p/8664680.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值