当前位置:首页 > 技术知识 > 正文内容

【Oracle】同实例中两个不同 owner 的表字段进行比较

maynowei6个月前 (09-09)技术知识57

文中使用的Oracle版本为10g。

本次介绍的脚本主要用于对同实例中的两个相同的表进行字段的差异比对。听起来很奇怪吧,这都是因为以前开发过程不规范导致的,不然不应该会出现这么荒唐的脚本才对。我说几个关键字估计大家都能够猜想到了,“联合开发”、“异地沟通”、“交叉开发”、“时间紧迫”、“在线排Bug”、“紧急修复”......

在这个脚本出来的时候,我个人还不知道Navicat这款软件(毕竟那时候还是小小的程序员没有想那么多,只着眼解决眼前的问题)不然直接用表结构对比就解决了。有一天线上出现问题,经排查发现上线时执行的数据库脚本存在问题,线上数据库与仿真数据库存在大量表结构差异。

一下子晴天霹雳,这无疑是重大事故。项目经理首当其冲领了盒饭(被辞退),之后就要考虑怎样修复问题。我那时候的提议被采纳了并且修复了这个问题。

以下操作在DBA和项目负责人陪同下一同完成:

  1. 找到一个干净的环境,将上线前一天晚上备份的dmp文件进行了还原(注意这里只还原了表结构);
  2. 再将现生产上的所有表进行表结构的备份,在同一个环境下还原;
  3. 之后根据以下脚本对表结构进行对比
select a.TABLE_NAME,
a.COLUMN_NAME as  acol, 
b.COLUMN_NAME as bcol, 
a.DATA_TYPE as adt,
a.DATA_LENGTH as adl,
b.DATA_TYPE as bdt,
b.DATA_LENGTH as bdl
from (
  (select a.TABLE_NAME,
     a.COLUMN_NAME,
     a.DATA_TYPE,
     a.DATA_LENGTH
     from DBA_TAB_COLUMNS a
     where a.OWNER = '<owner1>' 
     and a.TABLE_NAME='<table_name>'
    ) a 
  left join 
  (select a.TABLE_NAME,
     a.COLUMN_NAME,
     a.DATA_TYPE,
     a.DATA_LENGTH
     from DBA_TAB_COLUMNS a
     where a.OWNER = '<owner2>' 
     and a.TABLE_NAME='<table_name>'
    ) b 
  on a.COLUMN_NAME = b.COLUMN_NAME)

这个脚本能够定位到被修改过的字段和差异部分内容。

  1. 将差异内容导出来后让开发人员自行确认,并整理好修复脚本;

还好,这次事故修改的只是字段,若是触发器或者存储过程就麻烦了。
虽然整个修复过程只耗费了半小时,但是再一次让我觉得这个规范这个东西是很有必要的,很多时候项目为了快裁剪了很多东西后面要补的时候特别费劲。

相关文章

登录注册产品需求自检清单,你都写全了没?

来人人都是产品经理【起点学院】,BAT实战派产品总监手把手系统带你学产品、学运营。自己挖的坑一定要让别人给填好!一、登录(从PC端到移动端)移动端的登录沿袭了很多PC端的经验,但也有其独特的演变,我收...

去哪儿暑期PM实习一月记:在互联网公司做产品实习是怎样一种体验

人人都是产品经理旗下【起点学院】推出产品经理“365天”成长计划,BAT大牛带你学产品! 在毕业前的最后一个暑假,缘分使然找了几个月暑期实习之后进入了去哪儿,申请提前入职工作至今正好满一个月。原先有在...

2018年度回顾:挖矿木马为什么会成为病毒木马黑产的中坚力量

一、概述根据腾讯御见威胁情报中心监测数据,2018年挖矿木马样本月产生数量在百万级别,且上半年呈现快速增长趋势,下半年上涨趋势有所减缓。由于挖矿的收益可以通过数字加密货币系统结算,使黑色产业变现链条十...

记录程序第一天挖漏洞的过程(挖漏洞需要学什么语言)

第一个漏洞复现fastjson漏洞说明:在本地这个fastjson会出现问题复现的过程生成一个java文件进行攻击注入的方式javac Exploit.java但是必须编译成.class文件才能执行p...

有了这份900多页的Android面试指南,你离大厂Offer还远吗?

前言对于大部分程序员来说,一线互联网是的工作经历是毕生的追求,实际上大厂对于学历的要求远远没有我们想象的那么高,近几年来,互联网公司更注重技术,所以提升自身技术水平才是斩获offer的制胜关键。一线互...

c++ 继承简介(c++继承的概念)

24.1 — 继承简介2024 年 6 月 5 日在上一章中,我们讨论了对象组合,即从更简单的类和类型构建复杂类。对象组合非常适合构建与其部分具有“has-a”关系的新对象。但是,对象组合只是 C++...