标签云
asm恢复 bbed bootstrap$ dul In Memory kcbzib_kcrsds_1 kccpb_sanity_check_2 MySQL恢复 ORA-00312 ORA-00607 ORA-00704 ORA-00742 ORA-01110 ORA-01555 ORA-01578 ORA-01595 ORA-08103 ORA-600 2131 ORA-600 2662 ORA-600 3020 ORA-600 4000 ORA-600 4137 ORA-600 4193 ORA-600 4194 ORA-600 16703 ORA-600 kcbzib_kcrsds_1 ORA-600 KCLCHKBLK_4 ORA-15042 ORA-15196 ORACLE 12C oracle dul ORACLE PATCH Oracle Recovery Tools oracle加密恢复 oracle勒索 oracle勒索恢复 oracle异常恢复 Oracle 恢复 ORACLE恢复 ORACLE数据库恢复 oracle 比特币 OSD-04016 YOUR FILES ARE ENCRYPTED 勒索恢复 比特币加密文章分类
- Others (2)
- 中间件 (2)
- WebLogic (2)
- 操作系统 (103)
- 数据库 (1,769)
- DB2 (22)
- MySQL (77)
- Oracle (1,610)
- Data Guard (52)
- EXADATA (8)
- GoldenGate (24)
- ORA-xxxxx (166)
- ORACLE 12C (72)
- ORACLE 18C (6)
- ORACLE 19C (15)
- ORACLE 21C (3)
- Oracle 23ai (8)
- Oracle ASM (69)
- Oracle Bug (8)
- Oracle RAC (54)
- Oracle 安全 (6)
- Oracle 开发 (28)
- Oracle 监听 (29)
- Oracle备份恢复 (592)
- Oracle安装升级 (97)
- Oracle性能优化 (62)
- 专题索引 (5)
- 勒索恢复 (86)
- PostgreSQL (30)
- pdu工具 (6)
- PostgreSQL恢复 (9)
- SQL Server (32)
- SQL Server恢复 (13)
- TimesTen (7)
- 达梦数据库 (3)
- 达梦恢复 (1)
- 生活娱乐 (2)
- 至理名言 (11)
- 虚拟化 (2)
- VMware (2)
- 软件开发 (39)
- Asp.Net (9)
- JavaScript (12)
- PHP (2)
- 小工具 (22)
-
最近发表
- 2025年的Oracle 8.0.5数据库恢复
- ORA-600 kokiasg1故障分析(obj$中核心字典序列全部被恶意删除)
- ORA-00756 ORA-10567故障数据0丢失恢复
- 数据库文件变成32k故障恢复
- tcp连接过多导致监听TNS-12532 TNS-12560 TNS-00502错误
- 文件系统格式化MySQL数据库恢复
- .sstop勒索加密数据库恢复
- 解决一次硬件恢复之后数据文件0kb的故障恢复case
- Error in invoking target ‘libasmclntsh19.ohso libasmperl19.ohso client_sharedlib’问题处理
- ORA-01171: datafile N going offline due to error advancing checkpoint
- linux环境oracle数据库被文件系统勒索加密为.babyk扩展名溯源
- ORA-600 ksvworkmsgalloc: bad reaper
- ORA-600 krccfl_chunk故障处理
- Oracle Recovery Tools恢复案例总结—202505
- ORA-600 kddummy_blkchk 数据库循环重启
- 记录一次asm disk加入到vg通过恢复直接open库的案例
- CHECKDB 发现了 N 个分配错误和 M 个一致性错误
- 达梦数据库dm.ctl文件异常恢复
- Oracle Recovery Tools修复ORA-00742、ORA-600 ktbair2: illegal inheritance故障
- 可能是 tempdb 空间用尽或某个系统表不一致故障处理
月归档:八月 2011
诡异dblink问题解决
一、诡异dblink起源
今天开发拿过来一条sql,说有诡异现象,sql如下
INSERT INTO TAB_CS_CALLLOG select c.user_logon,/*工号*/c.user_name,/*姓名*/a.call_id,/*通话id*/ a.caller_nbr,/*主叫号码*/a.called_nbr,/*被叫号码*/d.start_time,/*呼入时间*/ b.call_time,/*接听时间*/b.end_time,/*结束时间*/b.call_dura,/*时长*/ to_number(b.call_time-d.start_time)*24*3600,/*等待时长*/ decode(c.user_logon,null,0,1),/*类型*/ case when substr (a.CALLED_NBR,7, 2) = '00' then '广东移动' when substr (a.CALLED_NBR,7, 2) = '01' then '浙江移动' when substr (a.CALLED_NBR,7, 2) = '02' then '福建' when substr (a.CALLED_NBR,7, 2) = '03' then '四川' when substr (a.CALLED_NBR,7, 2) = '04' then '河南' when substr (a.CALLED_NBR,7, 2) = '05' then '湖北' when substr (a.CALLED_NBR,7, 2) = '06' then '北京CSIP' when substr (a.CALLED_NBR,7, 2) = '07' then '陕西' when substr (a.CALLED_NBR,7, 2) = '08' then '吉林' when substr (a.CALLED_NBR,7, 2) = '09' then '江西' when substr (a.CALLED_NBR,7, 2) = '10' then '宁夏' when substr (a.CALLED_NBR,7, 2) = '11' then '太原' when substr (a.CALLED_NBR,7, 2) = '12' then '江苏移动' when substr (a.CALLED_NBR,7, 2) = '13' then 'e掌管' when substr (a.CALLED_NBR,7, 2) = '15' then 'e多商' when substr (a.CALLED_NBR,7, 2) = '18' then '江苏联通' end 区域 from cscnew.a@cs a,cscnew.b@cs b,cscnew.c@cs c,cscnew.d@cs d where a.call_serial=b.call_serial(+) and b.call_serial=d.call_serial(+) and b.user_id=c.user_id(+) and substr(a.CALLED_NBR,1, 6) = '951654' and length (a.CALLED_NBR) = 15 and b.fail_reason is null and a.end_time>=to_date('20110822000000','yyyymmddhh24miss') and a.end_time<to_date('20110823000000','yyyymmddhh24miss');
然后我进行了测试,证实了她所说的诡异:
1、直接执行select语句需要1.7S左右,但是加上insert inot后,执行时间需要6分钟
2、直接select结果集为602条,加上insert into后,结果集为598条(少4条),如果直接执行select,除掉and b.fail_reason is null限制条件也刚好602条
二、查询相关资料,得到dblink的一些解释
1、dblink执行有两种方式,一种是在远处数据库执行完,然后结果返回,另一种是把远程的表下载到本来,然后执行
2、如果把远程的表下载到本地,空值或者null可能会发生变化(怀疑是空值转化为null,未证实)
三、根据这些解释,进行猜想
1、只执行select的时候,应该是在远程执行完,传输结果回来;而执行insert into的时候,是把远程的表全部下载到本地,然后执行出结果,而数据量本身比较大,所以比较慢
2、在把表从远程下载到本地的过程中,fail_reason 列的null值可以发生了变化,或者空值变为了null,所以数据多了4条
四、事实证明猜想
1、查询远程表大小,发现a表50m,b表400m,c表10m,d表100m左右,传输过来需要一定的时间
2、既然猜测是由于要把表传输到本地而导致这样的结果产生,那么处理方法就是让程序在远程计算出结果,然后传输到本地,查询了一些资料,上面说insert into会导致driving_site提示无效,那么我想到一个用视图的办法解决这个问题:在目标端建立一个关于本查询中无参数的视图,然后在本地通过dblink调用视图,这样总该先在远程执行出结果传输到本地了吧。
2.1)建立目标端视图
create or replace view v_tab select c.user_logon,/*工号*/c.user_name,/*姓名*/a.call_id,/*通话id*/ a.caller_nbr,/*主叫号码*/a.called_nbr,/*被叫号码*/d.start_time,/*呼入时间*/ b.call_time,/*接听时间*/b.end_time,/*结束时间*/b.call_dura,/*时长*/ to_number(b.call_time-d.start_time)*24*3600,/*等待时长*/ decode(c.user_logon,null,0,1),/*类型*/ case when substr (a.CALLED_NBR,7, 2) = '00' then '广东移动' when substr (a.CALLED_NBR,7, 2) = '01' then '浙江移动' when substr (a.CALLED_NBR,7, 2) = '02' then '福建' when substr (a.CALLED_NBR,7, 2) = '03' then '四川' when substr (a.CALLED_NBR,7, 2) = '04' then '河南' when substr (a.CALLED_NBR,7, 2) = '05' then '湖北' when substr (a.CALLED_NBR,7, 2) = '06' then '北京CSIP' when substr (a.CALLED_NBR,7, 2) = '07' then '陕西' when substr (a.CALLED_NBR,7, 2) = '08' then '吉林' when substr (a.CALLED_NBR,7, 2) = '09' then '江西' when substr (a.CALLED_NBR,7, 2) = '10' then '宁夏' when substr (a.CALLED_NBR,7, 2) = '11' then '太原' when substr (a.CALLED_NBR,7, 2) = '12' then '江苏移动' when substr (a.CALLED_NBR,7, 2) = '13' then 'e掌管' when substr (a.CALLED_NBR,7, 2) = '15' then 'e多商' when substr (a.CALLED_NBR,7, 2) = '18' then '江苏联通' end 区域 from cscnew.a a,cscnew.b b,cscnew.c c,cscnew.d d where a.call_serial=b.call_serial(+) and b.call_serial=d.call_serial(+) and b.user_id=c.user_id(+) and substr(a.CALLED_NBR,1, 6) = '951654' and length (a.CALLED_NBR) = 15 and b.fail_reason is null
2.2)本地调用远程视图
INSERT INTO TAB_CS_CALLLOG select * from v_tab@cs a where a.end_time>=to_date('20110822000000','yyyymmddhh24miss') and a.end_time<to_date('20110823000000','yyyymmddhh24miss');
2.3)执行结果2.3S完成数据插入,而且条数也是598条,证明我的猜想是正确的,更重要的是解决了今天这个让人疑惑的问题
undo异常处理步骤(10g)
1、启动数据库,发现错误
startup
2、查看是否是undo文件损坏引起
select a.ts#,a.name,b.name from v$datafile a,v$tablespace b where a.ts#=b.ts#;
3、损坏undo离线
alter database datafile n offline drop;
4、打开数据库
alter database open;
5、查看当前undo表空间,并确认是否是当前undo损坏,如果不是当前undo,直接执行8,否则继续
show parameter undo_tablespace;
6、创建新undo表空间
CREATE UNDO TABLESPACE UNDOTBSNEW DATAFILE
‘/opt/oracle/oradata/xifenfei/UNDOTBS01.dbf
SIZE 50M autoextend on next 10m maxsize 30G;
7、修改默认undo为新创建表空间
alter system set undo_tablespace=’UNDOTBSNEW’;
8、查询回滚段信息,为下面删除损坏undo的回滚段做到心中有底
select segment_name,status from dba_rollback_segs;
9、删除损坏undo,如果报ORA-01548错误,继续下面操作,否则跳到14
drop tablespace UNDOTBSOLD including contents and datafiles;
10、创建pfile文件
create pfile=’/tmp/pfile’ from spfile;
11、修改pfile文件,添加隐含参数
*._allow_resetlogs_corruption=true
*._corrupted_rollback_segments=(_SYSSMU1$,_SYSSMU2$,_SYSSMU3$,_SYSSMU4$,_SYSSMU5$,
_SYSSMU6$,_SYSSMU7$,_SYSSMU8$,_SYSSMU9$,_SYSSMU10$)
12、使用pfile启动数据库
startup pfile=’/tmp/pfile’
13、删除损坏undo
drop tablespace UNDOTBSOLD including contents and datafiles;
14、查看回滚段状态
select segment_name,status from dba_rollback_segs;
15、如果有损坏表空间回滚段还存在,手工删除
drop rollback segment “_SYSSMUx$”;
16、重启数据库
shutdown immediate
startup
发表在 Oracle备份恢复
6 条评论
Linux修改系统时间
我们一般使用’date -s’命令来修改系统时间。比如将系统时间设定成2011年8月24日的命令如下。
#date -s 08/24/2011
将系统时间设定成下午23点0分20秒的命令如下。
#date -s 23:00:20
注意,这里说的是系统时间,是linux由操作系统维护的。
在系统启动时,Linux操作系统将时间从CMOS中读到系统时间变量中,以后修改时间通过修改系统时间实现。为了保持系统时间与CMOS时间的一致性,Linux每隔一段时间会将系统时间写入CMOS。由于该同步是每隔一段时间(大约是11分钟)进行的,在我们执行date -s后,如果马上重起机器,修改时间就有可能没有被写入CMOS,这就是问题的原因。如果要确保修改生效可以执行如下命令。
#clock -w
这个命令强制把系统时间写入CMOS。
发表在 Linux
评论关闭