posts - 5, comments - 0, trackbacks - 0, articles - 0
  BlogJava :: 首页 :: 新随笔 :: 联系 :: 聚合  :: 管理

oracle sql 4则

Posted on 2011-06-27 00:31 火炎炎 阅读(182) 评论(0)  编辑  收藏
  • 如果存在就更新,不存在就插入用一个语句实现
MERGE  INTO  t_mg a
USING (
SELECT   ' the code '  code,  ' the name '  NAME  FROM
 dual) b
ON  (a.code  =
 b.code)
WHEN  MATCHED  THEN

UPDATE   SET  a.NAME  =  b.NAME
WHEN   NOT  MATCHED  THEN

INSERT  (code, NAME)  VALUES  (b.code, b.NAME);
  • 分页算法

SELECT   *
FROM  ( SELECT  a. * , ROWNUM rn
FROM  ( SELECT   *   FROM  t_employees  ORDER   BY
 first_name) a
WHERE  ROWNUM  <=   500
)
WHERE  rn  >   480  ;

  • 抽取/删除重复记录

1) 部分字段重复数据的删除

delete   from  表名 a 
where  a.rowid  !=
 
(
select   max (b.rowid)  from
 表名 b 
where  a.字段1  =  b.字段1  and
 
a.字段2 
=
 b.字段2 
)

上面语句的执行效率是很低的,可以考虑建立临时表,讲需要判断重复的字段、rowid插入临时表中,然后删除的时候在进行比较。

create   table  临时表  as  
select  a.字段1,a.字段2, MAX (a.ROWID) dataid  from  正式表 a  GROUP   BY
 a.字段1,a.字段2;
delete   from
 表名 a 
where  a.rowid  !=
 
(
select  b.dataid  from
 临时表 b 
where  a.字段1  =  b.字段1  and
 
a.字段2 
=
 b.字段2 
)

2) 完全重复记录的删除

用下面语句获取到去掉重复数据后的记录:

select   distinct   *   from  表名

可以将查询的记录放到临时表中,然后再将原来的表记录删除,最后将临时表的数据导回原来的表中。如下:

CREATE   TABLE  临时表  AS  ( select   distinct   *   from  表名);
drop   table
 正式表;
insert   into  正式表 ( select   *   from
 临时表);
drop   table  临时表;

执行上记SQL语句,可以查寻到数据库中的锁的情报.

SELECT   S.SID SESSION_ID, S.USERNAME, DECODE(LMODE,  0 ' None ' 1 ' Null ' 2 ' Row-S (SS) ' 3 ' Row-X (SX) ' ,   4 ' Share ' 5 ' S/Row-X (SSX) ' ,   6 ' Exclusive ' , TO_CHAR(LMODE)) MODE_HELD, DECODE(REQUEST,  0 ' None ' 1 ' Null ' 2 ' Row-S (SS) ' 3 ' Row-X (SX) ' 4 ' Share ' 5 ' S/Row-X (SSX) ' 6 ' Exclusive ' , TO_CHAR(REQUEST)) MODE_REQUESTED, O.OWNER || ' . ' || O. OBJECT_NAME || '  ( ' || O.OBJECT_TYPE || ' ) ' , S.TYPE LOCK_TYPE, L.ID1 LOCK_ID1, L.ID2 LOCK_ID2 
FROM
 V$LOCK L, SYS.DBA_OBJECTS O, V$SESSION S 
WHERE  L.SID  =  S.SID  AND   L.ID1  =  O. OBJECT_ID
SESSION_ID, USERNAME,  MODE_HELD,  MODE_REQUESTED, OBJECT_NAME, LOCK_TYPE, LOCK_ID
分别是 拥有锁的SESSION_ID,拥有锁的USERNAME,锁的执行模式MODE_HELD,锁的请求MODE_REQUESTED,锁所在的数据库对象名
,锁的类型,锁的ID

只有注册用户登录后才能发表评论。


网站导航: