[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
--//与原来计算结果一样.

[20170410]快速找回触发器内容.txt相关推荐

  1. Android 备忘录删除功能,安卓手机便签删除了怎么恢复?有可以快速找回删除内容的备忘录软件吗...

    原标题:安卓手机便签删除了怎么恢复?有可以快速找回删除内容的备忘录软件吗 现在,如果去买手机的话,估计很多人都会选择智能手机.毕竟,只有在智能手机上才能安装使用这样或那样的app软件,使我们的生活越来 ...

  2. Linux运维:快速清空文本内容

    文章目录 快速清空文件内容 方式一: ggdG 方式二:%d 方式三:.,%d 方式四:echo > a.txt 快速清空文件内容 方式一: ggdG 首先回到首行 gg 然后,注意G是大写的( ...

  3. 手机计算机桌面图标恢复,三种方法快速找回桌面图标(附电脑文件恢复教程)...

    三种方法快速找回桌面图标!大家应该都喜欢把自己经常用到的图标放到桌面上吧.当我们需要进行一些操作的时候,直接点击桌面上的图标就能进入相应的界面.大大节省了我们的时间,让我们的办公更加便捷.如果我们的桌 ...

  4. Mac回收站清空还能恢复吗?2个方法快速找回废纸篓清空文件

    Mac回收站清空还能恢复吗?使用Mac苹果电脑的用户都知道废纸篓(即回收站),是一个非常好用的功能,它可以将用户所有删除的文件给集合到一起,在用户后悔的时候可以还原.不过废纸篓使用的是电脑驱动盘的内存 ...

  5. 【快速找回删除的文件的方法汇总】

    电脑的文件不能堆积太多,有时候要适当的做些清理,但是清理的时候不排除会有误删的情况,如果发生这样的情况该怎么快速找回删除的文件呢? 一.首先是免费软件 在GiveAwayofTheDay网站上有一个栏 ...

  6. 三种快速转换PDF为TXT的方法:简单、高效、免费

    如何将PDF转换为TXT文件?在日常生活中,PDF和TXT是常见的文本格式.PDF格式文件具有稳定的布局和易于存储的特点.然而,许多在线下载的电子书通常是以PDF格式提供的,而电子阅读器通常不支持PD ...

  7. 开机不进去桌面执行gui_电脑系统崩溃进不去,简单几步设置U盘,快速找回桌面重要文件...

    hello~我可爱的粉丝们!今天粮小白分享一个电脑系统崩溃无法开机,怎么把电脑数据保存备份的小技能,就来就点个关注吧.每天更新生活必备技能哦. 电脑系统崩溃进不去,简单几步设置U盘,快速找回桌面重要文 ...

  8. iphone通讯录批量删除_iPhone通讯录删除了如何恢复?用对方法快速找回,亲测有效!_...

    2020年11月03日 16:50作者:黄页编辑:黄页 iPhone通讯录删除了如何恢复?很多时候我们都已经习惯了用微信去传递感情,去跟朋友或者是同事沟通,因为这样既方便又快捷,小编也是如此.但是很多 ...

  9. linux vi快速删除文本内容

    vi快速删除文本内容 :%d 转载于:https://blog.51cto.com/william1227/1431903

最新文章

  1. oracle9i.rar下载
  2. python与excel的差别-python数据分析相对于bi和excel的优势是什么?
  3. Intellij IDEA神器居然还有这些小技巧
  4. 大四 PHP《上传文件》
  5. Windows使用opencv训练模型过程记录(提供样本)
  6. .NET Core 3.0中的数据库驱动框架System.Data
  7. CoreAnimation编程指南(七)图层Action
  8. DailyWallpaper v1.02 released
  9. 报错解决:No module named tensorflow.contrib
  10. mysql安装包提示选项_Windows操作系统安装MySQL解压版
  11. 图像质量评价方法介绍
  12. Asp.net Web Api开发(第四篇)Help Page配置和扩展
  13. 苹果系统虚拟机无usb服务器,win10系统苹果电脑运行虚拟机后无法识别显示U盘的详细方案...
  14. DC - 13 :顺序表
  15. 大林算法计算机控制实验报告,实验二 大林算法实验报告
  16. mysql读写分离踩坑记
  17. 进入Recovery模式方法
  18. AndroidQ SettingsProvider和Settings原理
  19. unity法线贴图,光线烘培的应用
  20. 图片无损放大,让细节美到毛孔——PhotoZoom Pro小能手来咯

热门文章

  1. 贪婪算法在解决哈夫曼树及编码问题中的应用
  2. 我的ELK搭建笔记(阿里云上部署)
  3. python字典导入mongodb_python连接mongoDB进行数据提取→常用操作指南
  4. Java运算符优先级和表达式及数据类型转换
  5. ios图文详情加载html_前端项目009 Vue 信息分享系统 商品列表、详情
  6. python未将对象引用设置到对象的实例_在Python中使用pingarapi。服务器引发Webfault:对象引用未设置为对象的实例...
  7. 网路工程师要不要学mysql_网络工程师要学什么_网络工程师需要的技能
  8. 重启java_让Java程序自动重启的实现方法(推荐)
  9. linux下搭建nagios监控
  10. Spring中解决事务以及异步注解失效