[20170410]快速找回触发器内容.txt

[20170410]快速找回触发器内容.txt

--上午登录发现一个是触发器被人为删除了,需要恢复.链接http://www.itpub.net/thread-2084789-1-1.html.
--我提供几个方法:1.取出备份的system数据文件,通过bbed之类的工具定位.2使用logminer 应该也可以定位,表sys.source$.

--实际上还有1个简单粗暴的方法,直接通过strings查询归档日志.例子如下:

1.环境:
SYS@book> @ &r/ver1
PORT_STRING                    VERSION        BANNER
------------------------------ -------------- --------------------------------------------------------------------------------
x86_64/Linux 2.4.xx            11.2.0.4.0     Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production

--//我的测试环境很早建立的一个函数.
CREATE OR REPLACE function SCOTT.p2p_distance(
            p_latitude1 number,
            p_longitude1 number,
            p_latitude2 number,
            p_longitude2 number) return number deterministic is
  earth_radius  number := 6371;
  pi_approx     number := 3.1415197/180;
  lat_delta     number := (p_latitude2-p_latitude1)*pi_approx;
  lon_delta     number := (p_longitude2-p_longitude1)*pi_approx;
  arc           number := sin(lat_delta/2) * sin(lat_delta/2) +
                               sin(lon_delta/2) * sin(lon_delta/2) * cos(p_latitude1*pi_approx) * cos(p_latitude2*pi_approx);
begin
  return earth_radius * 2 * atan2(sqrt(arc), sqrt(1-arc));
end;
/

2.删除它,恢复看看.
SYS@book> @ &r/logfile
GROUP# STATUS TYPE       MEMBER                          IS_ GROUP# THREAD# SEQUENCE#       BYTES BLOCKSIZE MEMBERS ARC STATUS     FIRST_CHANGE# FIRST_TIME          NEXT_CHANGE# NEXT_TIME
------ ------ ---------- ------------------------------- --- ------ ------- --------- ----------- --------- ------- --- ---------- ------------- ------------------- ------------ -------------------
     1        ONLINE     /mnt/ramdisk/book/redo01.log    NO       1       1       815    52428800       512       1 YES INACTIVE     13277272313 2017-04-08 16:00:41  13277278586 2017-04-10 08:43:12
     2        ONLINE     /mnt/ramdisk/book/redo02.log    NO       2       1       816    52428800       512       1 YES INACTIVE     13277278586 2017-04-10 08:43:12  13277278900 2017-04-10 08:43:16
     3        ONLINE     /mnt/ramdisk/book/redo03.log    NO       3       1       817    52428800       512       1 NO  CURRENT      13277278900 2017-04-10 08:43:16 2.814750E+14
     4        STANDBY    /mnt/ramdisk/book/redostb01.log NO
     5        STANDBY    /mnt/ramdisk/book/redostb02.log NO
     6        STANDBY    /mnt/ramdisk/book/redostb03.log NO
     7        STANDBY    /mnt/ramdisk/book/redostb04.log NO
7 rows selected.

--//当前在线日志/mnt/ramdisk/book/redo03.log .

SYS@book> drop function SCOTT.p2p_distance;
Function dropped.

SYS@book> alter system checkpoint ;
System altered.

SYS@book> alter system checkpoint ;
System altered.

SYS@book> alter system checkpoint ;
System altered.
--//保证脏块写盘.

$ strings -3 /mnt/ramdisk/book/redo03.log > /tmp/aaa.txt

drop function SCOTT.p2p_distance
SCOTT
P2P_DISTANCE
ORA$BASE.,
YYYY-MM-DD HH24:MI:SS
YYYY-MM-DD HH24:MI:SS.FFHH.MI.SSXFF AM
HH.MI.SSXFF AM TZR
YYYY-MM-DD HH24:MI:SS.FF TZH:TZMAMERICANAMERICANGREGORIAN
BINARY
BINARY
AMERICA
AMERICA
BYTEFALSE
    _H--------------------------------------
function p2p_distance(
            p_latitude1 number,
            p_longitude1 number,
            p_latitude2 number,
            p_longitude2 number) return number deterministic is
  earth_radius  number := 6371;
  pi_approx     number := 3.1415197/180;
  la
t_delta     number := (p_latitude2-p_latitude1)*pi_approx;
  lon_delta     number := (p_longitude2-p_longitude1)*pi_approx;
  arc           number := sin(lat_delta/2) * sin(lat_delta/2) +
                               sin(lon_delta
6/2) * sin(lon_delta/2) * cos(p_latitude1*pi_approx) * cos(p_latitude2*pi_approx);
~~
begin
  return earth_radius * 2 * atan2(sqrt(arc), sqrt(1-arc));
end;
U7^M

--//ok,里面就有内容.改写一下就ok了:(注有一点点小错误,里面多了1个6,注意看下划线)
CREATE OR REPLACE function SCOTT.p2p_distance(
            p_latitude1 number,
            p_longitude1 number,
            p_latitude2 number,
            p_longitude2 number) return number deterministic is
  earth_radius  number := 6371;
  pi_approx     number := 3.1415197/180;
  lat_delta     number := (p_latitude2-p_latitude1)*pi_approx;
  lon_delta     number := (p_longitude2-p_longitude1)*pi_approx;
  arc           number := sin(lat_delta/2) * sin(lat_delta/2) +
                               sin(lon_delta/2) * sin(lon_delta/2) * cos(p_latitude1*pi_approx) * cos(p_latitude2*pi_approx);
begin
  return earth_radius * 2 * atan2(sqrt(arc), sqrt(1-arc));
end;
/

--//在引申一点,实际上你可以直接扫描system01.dbf文件找到对应的内容.正常业务数据库一般不会有大量的dml对于sys.source$表.

SYS@book> column PARTITION_NAME noprint
SYS@book> select * from (select * from dba_extents where segment_name='SOURCE$' order by block_id desc) where rownum=1;
OWNER  SEGMENT_NAME         SEGMENT_TYPE       TABLESPACE_NAME                 EXTENT_ID    FILE_ID   BLOCK_ID      BYTES     BLOCKS RELATIVE_FNO
------ -------------------- ------------------ ------------------------------ ---------- ---------- ---------- ---------- ---------- ------------
SYS    SOURCE$              TABLE              SYSTEM                                 79          1      91520    8388608       1024            1

--//最后1块在91520.占用1024块.
SYS@book> select (91520+1024-1)*8192 from dual ;
(91520+1024-1)*8192
-------------------
          758112256

--//91520+1024=92544

$ dd if=/mnt/ramdisk/book/system01.dbf bs=8192 count=92544 | strings -3 > /tmp/bbb.txt
92544+0 records in
92544+0 records out
758120448 bytes (758 MB) copied, 11.8657 seconds, 63.9 MB/s

--//查询可以找到如下:

function p2p_distance(
    _H
             p_latitude1 number,
    _H
!            p_longitude1 number,
    _H
             p_latitude2 number,
    _H
@            p_longitude2 number) return number deterministic is
    _H
   earth_radius  number := 6371;
    _H
)  pi_approx     number := 3.1415197/180;
    _H
    ?  lat_delta     number := (p_latitude2-p_latitude1)*pi_approx;
    _H
A  lon_delta     number := (p_longitude2-p_longitude1)*pi_approx;
    _H
@  arc           number := sin(lat_delta/2) * sin(lat_delta/2) +
    _H
~                               sin(lon_delta/2) * sin(lon_delta/2) * cos(p_latitude1*pi_approx) * cos(p_latitude2*pi_approx);
    _H
begin
    _H
;  return earth_radius * 2 * atan2(sqrt(arc), sqrt(1-arc));
    _H
end;,

--//编辑一下就ok了.感觉看归档日志更好一些.重新建立后

SCOTT@book> select p2p_distance(36.12, -86.67, 33.94, -118.4) from dual;

P2P_DISTANCE(36.12,-86.67,33.94,-118.4)
---------------------------------------
                             2886.40705
--//与原来计算结果一样.

时间: 2024-09-20 15:32:47

[20170410]快速找回触发器内容.txt的相关文章

[20170410]快速找回触发器内容2.txt

[20170410]快速找回触发器内容2.txt --上午登录发现一个是触发器被人为删除了,需要恢复.链接http://www.itpub.net/thread-2084789-1-1.html. --我提供几个方法:1.取出备份的system数据文件,通过bbed之类的工具定位.2使用logminer 应该也可以定位,表sys.source$. --实际上还有1个简单粗暴的方法,直接通过strings查询归档日志.链接: http://blog.itpub.net/267265/viewspa

[20130116]ASM未正常启动,使用dd找回数据文件.txt

[20130116]ASM未正常启动,使用dd找回数据文件.txt 参考链接:http://www.xifenfei.com/3025.html,自己为了加强理解,重做一次. SQL> column name format a50 SQL> select file#,ts#,status,enabled,checkpoint_change#,name,bytes  from v$datafile;      FILE#        TS# STATUS  ENABLED    CHECKPO

教你快速将多个TXT文档合并成一个

网上下载的文件常常会分割成好几个文件,阅读起来非常不便,本教程为大家介绍如何快速将多个txt文件合并. 文档合并成一个-快速合并word文档"> 同时选定需要合并的txt文档进行压缩 步骤1:首先选中需要合并的多个TXT文档,然后单击鼠标右键,在弹出的菜单中选中"Win-RAR-添加到压缩文件"命令,这时会出现"压缩文件名和参数"窗口,在"常规"标签页中对压缩文件进行命名,并将"压缩方式"下拉框中的"

Word文档中快速输入特定内容的方法

  Word文档中快速输入特定内容的方法           1.单击"文件"按钮,在打开的面板中选择"选项". 2.此时会打开名为"Word选项"的窗口,在左侧选择"校对"命令,然后在右侧的窗口中找到"自动更正选项"按钮. 3.在"自动更正"选项卡的"替换"文本框中为自己需要重复输入的内容设置一个"快捷键"(例如<1>),然后在&qu

快速找回Win8/Win8.1中消失了的系统评分

  对此有许多使用Win8/Win8.1的小伙伴因为看不到评分,总觉得心里不自在,其实Win8/Win8.1系统评分这项功能只是被隐藏了,至于微软为何要将它隐藏,那就不得而知了,但是我们可以通过如下方法快速找回Win8/Win8.1中消失了的系统评分. 1.下载PerfCenterCPL.dll应用程序扩展合集. 2.下载后将文件解压至桌面,然后将Windows文件夹复制到你的系统盘(一般为C盘),复制完成后以管理员身份运行WinSat.bat ,运行前确保WinSat.bat和PerfCent

左明燕:怎样快速更新网站内容

中介交易 http://www.aliyun.com/zixun/aggregation/6858.html">SEO诊断 淘宝客 云主机 技术大厅 从有了CMS现在做个网站是件非常简单的事,网站的运作的中心是日常的网站内容更新和长期网站推广.其中网站内容的快速更新是重中之重,小左来分享一下快速更新网站内容的几种方法.希望能为站长们更新网站内容提供一些帮助. 1.内容采集 内容采集是最直接的方法,采集回来的内容只要经过筛选和相关编辑发布出来就可以起到快速更新网站内容的作用.但采集也有个致命

兼职站长应当如何快速增加网站内容

中介交易 http://www.aliyun.com/zixun/aggregation/6858.html">SEO诊断 淘宝客 云主机 技术大厅 物价的不断飙升,越来越多的白领阶级.工薪阶级进入了互联网中,都想在互联网中赚取一些零花钱,我们把这种不是专职做站的站长称为:兼职站长,那么兼职站长时间有限,又如何快速的增加网站内容呢? 1.威客要利用,每天几元有大用 作为一名兼职的站长,需要用最少的钱换取最大的利益,每天网站的更新必不可少,那么就要用到威客了,在威客去发布任务,每天只需要几篇

手机丢失通讯录没了 360云盘可快速找回

对很 多人而言,丢失手机是件很麻烦的事情,除了要去营业厅卡.办卡外,手机内通讯录的丢失也用户头疼不已.南京市民杨女士在逛街的时候把手机丢了,"手机号还能补, 但是通讯录无法找回,几百个电话号码就这么没了."如何找回手机内重要信息,省去重新 手动更新信息的烦恼呢?今天小编就教大家用http://www.aliyun.com/zixun/aggregation/9419.html">360云盘快速找回通讯录,简单几步即可恢复,再也 不用为手机丢失而烦恼了.   手机上安装3

手机丢失通讯录没了360云盘可快速找回

对很多人而言,丢失手机是件很麻烦的事情,除了要去营业厅卡.办卡外,手机内通讯录的丢失也用户头疼不已.南京市民杨女士在逛街的时候把手机丢了,"手机号还能补,但是通讯录无法找回,几百个电话号码就这么没了."如何找回手机内重要信息,省去重新手动更新信息的烦恼呢?今天小编就教大家用360云盘快速找回通讯录,简单几步即可恢复,再也不用为手机丢失而烦恼了.手机上安装360云盘的APP先在手机上安装360云盘APP,(http://yunpan.360.cn/index/download#andro