Oracle 相关积累

1.查表被谁锁定

select object_name as tableName ,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;

2.解锁

alter system kill session '1,222'; --(其中1,222分别是上面查询出的sid,serial#)

3.查看锁表及解锁:

 一、处理过程

      1.通过查找出已被锁定的数据库表及相关的sid、serial#及spid:

        select object_name as 对象名称,s.sid,s.serial#,p.spid as 系统进程号

        from v$locked_object l , dba_objects o , v$session s , v$process p

        where l.object_id=o.object_id and l.session_id=s.sid and s.paddr=p.addr;

        2.在数据库中kill掉相关session:

       alter system kill session 'sid,serial#';

      --sid及serial#为第一步查出来的数据

        3.从系统中灭掉与该session对应的进程:

       kill -9 spid;

      --spid为第一步中查出来的系统进程号

      经过以上操作之后重新对之前锁定的对象进行操作应该就可以了。

二、使用了相关表的基本介绍

  • V$LOCKED_OBJECT中的列说明:

    XIDUSN:回滚段号

    XIDSLOT:槽号

    XIDSQN:序列号

    OBJECT_ID:被锁对象ID

    SESSION_ID:持有锁的sessionID

    ORACLE_USERNAME:持有锁的Oracle 用户名

    OS_USER_NAME:持有锁的操作系统 用户名

    PROCESS:操作系统进程号

    LOCKED_MODE:锁模式

  • dba_objects的列说明(网上找的,懒得翻译了^_^)

    OWNER

              Username of the owner of the object

        OBJECT_NAME

              Name of the object

        SUBOBJECT_NAME

              Name of the sub-object (for example,partititon)

        OBJECT_ID

              Object number of the object

        DATA_OBJECT_ID

              Object number of the segment which contains the object

        OBJECT_TYPE

              Type of the object

        CREATED

              Timestamp for the creation of the object

        LAST_DDL_TIME

              Timestamp for the last DDL change (including GRANT and REVOKE) to the object

        TIMESTAMP

              Timestamp for the specification of the object

        STATUS

              Status of the object

        TEMPORARY

              Can the current session only see data that it place in this object itself?

        GENERATED

              Was the name of this object system generated?

        SECONDARY

              Is this a secondary object created as part of icreate for domain indexes?

  • v$session的说明

    V$SESSION是基础信息视图,用于找寻用户SID或SADDR

    常用列:

    SID:SESSION标识

    SERIAL#:如果某个SID又被其它的session使用的话则此数值自增加(当一个SESSION结束,另一个SESSION开始并使用了同一个SID)。

    AUDSID:审查session ID唯一性,确认它通常也用于当寻找并行查询模式

    USERNAME:当前session在oracle中的用户名。

    STATUS:这列用来判断session状态是:

        Achtive:正执行SQL语句(waiting for/using a resource)

        Inactive:等待操作(即等待需要执行的SQL语句)

        Killed:被标注为删除

  • v$process视图

    v$process视图包含当前系统Oracle运行的所有进程信息。常被用于将Oracle或服务进程的操作系统进程ID与数据库session之间建立联系。

    常用列:

    ADDR:进程对象地址

    PID:oracle进程ID

    SPID:操作系统进程ID

一些ORACLE中的进程被杀掉后,状态被置为"killed",但是锁定的资源很长时间不释放,有时实在没办法,只好重启数据库。但是shutdown immediate又怕可能进程杀不掉会一直停留在shutdown immediate,直接shutdown abort又怕损坏数据库。
现在提供一种方法解决这种问题,那就是在ORACLE中杀不掉的,在OS一级再杀。
1.下面的语句用来查询哪些对象被锁:
SELECT S.USERNAME,S.OSUSER,S.SID,S.SERIAL#,P.SPID FROM V$SESSION S,V$PROCESS
P WHERE S.PADDR=P.ADDR AND S.USERNAME IS NOT NULL;
2.下面的语句用来杀死一个进程:
alter system kill session 'sid,serial#';
【注】以上两步,可以通过Oracle的管理控制台来执行。
如果出现题目的错误,可以
select a.spid,b.sid,b.serial#,b.username from v$process a,v$session b where a.addr=b.paddr and b.status='KILLED' ;
3.如果利用上面的命令杀死一个进程后,进程状态被置为"killed",但是锁定的资源很长时间没有被释放,那么可以在os一级再杀死相应的进程(线程),首先执行下面的语句获得进程(线程)号:
select spid, osuser, s.program from v$session s,v$process p where
s.paddr=p.addr and s.sid=33 (33就是上面的sid)
4.在OS上杀死这个进程(线程):
1)在unix上,用root身份执行命令:
#kill -9 12345(即第3步查询出的spid)
2)在windows(unix也适用)用orakill杀死线程,orakill是oracle提供的一个可执行命令,语法为:
orakill sid thread
其中:
sid:表示要杀死的进程属于的实例名
thread:是要杀掉的线程号,即第3步查询出的spid。
例:c:>orakill orcl 12345
Ps:这里要注意的是kill OS进程是在服务端操作,而不是你程序所在客户机。

4.行列变换

Pivot, Unpivot

5.LENGTH(string1) 返回以字符为单位的长度.

LENGTHB(string1) 返回以字节为单位的长度.
LENGTHC(string1) 返回以Unicode完全字符为单位的长度.
LENGTH2(string1) 返回以UCS2代码点为单位的长度.
LENGTH4(string1) 返回以UCS4代码点为单位的长度.

不同字符集,对汉字的编码是不一样的,
例如ZHS16GBK是两位,采用两个byte位来定义一个汉字。
而在UTF8,采用3个byte。
总之,lengthb的值和你当前数据库的字符集是有关的。

6.列、procedure查询

SELECT * FROM all_tab_columns t WHERE t.OWNER='test' and t.COLUMN_NAME='F1'
select *from all_procedures t where t.OWNER='test';
select * from user_source where type='PROCEDURE'

7Java函数

8i以上版本可以创建一个如下的java函数 
SQL> create   or   replace   and   compile   
java   source 
named   "MyTimestamp " 
as 
import   java.lang.String; 
import   java.sql.Timestamp; 

public   class   MyTimestamp 

public   static   String   getTimestamp() 

return(new   Timestamp(System.currentTimeMillis())).toString(); 

}; 
SQL> java   created. 
注:注意java的语法,注意大小写 
SQL> create   or   replace   function   my_timestamp   return   varchar2 
as   language   java 
name   'MyTimestamp.getTimestamp()   return   java.lang.String '; 

SQL> function   created. 
SQL> select   my_timestamp,to_char(sysdate, 'yyyy-mm-dd   hh24:mi:ss ')   ORACLE_TIME   from   dual; 
MY_TIMESTAMP   ORACLE_TIME 
------------------------   ------------------- 
2003-03-17   19:15:59.688   2003-03-17   19:15:59   
如果只想获得1/100秒(hsecs),还可以利用dbms_utility.get_time

8---------------------------------------------------------

取字段COMMENT

SELECT   TABLE_NAME,  COLUMN_NAME,   COMMENTS

    FROM     USER_COL_COMMENTS

 WHERE  TABLE_NAME = 'MR_DEPT'

 

取表的说明

SELECT  *   FROM    USER_TAB_COMMENTS   WHERE    TABLE_NAME = 'MR_DEPT'

 

取字段的数据类型

SELECT  *  FROM    USER_TAB_COLUMNS
WHERE TABLE_NAME='WZ_ZBGG'


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值