1. 程式人生 > >Oracle語句

Oracle語句

  1. 查看錶空間的使用情況
--查看錶空間的使用情況
SELECT Upper(F.TABLESPACE_NAME)         "表空間名",
       D.TOT_GROOTTE_MB                 "表空間大小(M)",
       D.TOT_GROOTTE_MB - F.TOTAL_BYTES "已使用空間(M)",
       To_char(Round(( D.TOT_GROOTTE_MB - F.TOTAL_BYTES ) / D.TOT_GROOTTE_MB * 100, 2), '990.99')
       || '%'                           "使用比",
       F.TOTAL_BYTES                    "空閒空間(M)",
       F.MAX_BYTES                      "最大塊(M)"
FROM   (SELECT TABLESPACE_NAME,
               Round(Sum(BYTES) / ( 1024 * 1024 ), 2) TOTAL_BYTES,
               Round(Max(BYTES) / ( 1024 * 1024 ), 2) MAX_BYTES
        FROM   SYS.DBA_FREE_SPACE
        GROUP  BY TABLESPACE_NAME) F,
       (SELECT DD.TABLESPACE_NAME,
               Round(Sum(DD.BYTES) / ( 1024 * 1024 ), 2) TOT_GROOTTE_MB
        FROM   SYS.DBA_DATA_FILES DD
        GROUP  BY DD.TABLESPACE_NAME) D
WHERE  D.TABLESPACE_NAME = F.TABLESPACE_NAME
--按照第幾列排序
ORDER  BY 1
  1. 查詢連線Session a.查詢所有連線會話

    SELECT /*+ rule */ s.username,
    decode(l.type,'TM','TABLE LOCK',
    'TX','ROW LOCK',
    NULL) LOCK_LEVEL,
    o.owner,o.object_name,o.object_type,
    s.sid,s.serial#,s.terminal,s.machine,s.program,s.osuser
    FROM v$session s,v$lock l,dba_objects o
    WHERE l.sid = s.sid
    AND l.id1 = o.object_id(+)
    AND s.username is NOT Null
    

    b.查詢鎖表執行緒

    select object_name,machine,s.sid,s.serial#
    from v$locked_object l,dba_objects o ,v$session s
    where l.object_id = o.object_id and l.session_id=s.sid
    

    c.kill掉對應鎖表連線

    alter system kill session 'SID,SERIAL#'
    

    d.如果c不能解決,查詢程序號,去伺服器上kill程序

    select spid, osuser, s.program --spid是程序號
    from v$session s,v$process p 
    where s.paddr=p.addr and s.sid=267;--267是上一步的sid
    --到資料庫伺服器上去kill這個程序
    -- kill -9 xxxx(程序號//-9表示強行終止)
    
  2. 查詢當前使用者的所有表

select * from all_tables where owner='TEST';
--使用者名稱大寫
  1. 顯示錶欄位資訊
select * 
from user_tab_columns 
where Table_Name='CUSTOMER' --換成自己表名,大寫
order by column_name