返回顶部
首页 > 资讯 > 数据库 >Oracle补充日志supplemental log的示例分析
  • 858
分享到

Oracle补充日志supplemental log的示例分析

2024-04-02 19:04:59 858人浏览 泡泡鱼
摘要

这篇文章给大家介绍oracle补充日志supplemental log的示例分析,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。 Oracle 补充日志(su

这篇文章给大家介绍oracle补充日志supplemental log的示例分析,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

Oracle 补充日志(supplemental log)

附加日志(supplemental log)可以指示数据库在日志中添加额外信息到日志流中,以支持基于日志的工具,如逻辑standby、streams、GoldenGate、LogMiner。可以在数据库和表上设置。
 
1.数据库级设置,分两类:
1.1最小附加日志(minimal supplemental logging):
DATA选项启用最小附加日志。

启用最小日志可以确保LogMiner(或其他任何基于LogMiner的产品)可以支持行链接、簇表、索引组织表等。
语法如下:
alter database {add|drop} supplemental log data;
 
1.2标识键日志(identification key logging):
DATA(all,primary key,unique,foreign key) columns选项启用最小日志及列数据日志。
在源库日志为变化来源同步其他数据库的情况下,比如逻辑备用数据库,受影响的数据行必须以列数据标识(而不是rowid),必须启用此种附加日志。
语法如下:
alter database {add|drop} supplemental log {data(all,primary key,unique,foreign key) columns};
 
缺省情况下,Oracle不启用以上任何附加日志。当使用ALL,PRIMARY,UNIQUE或FOREIGN附加日志时最小补全日志默认开启(即检查结果为IMPLICIT)。 在删除所有导致IMPLICIT最小化附加日志的附加日志后,最小化附加日志变为NO。
 
查询当前设置是否开启最小补充日志:
SELECT supplemental_log_data_min min,
       supplemental_log_data_pk pk,
       supplemental_log_data_ui ui,
       supplemental_log_data_fk fk,
       supplemental_log_data_all allc
  FROM v$database;


MIN      PK  UI  FK  ALL
-------- --- --- --- ---
NO       NO  NO  NO  NO

SQL>
 
2,表级附加日志设置,分两类
2.1,可以通过以下语句设置命名日志组:
语法:
alter table table_name
add supplemental log group group_a(column_a [no log],column_b,...) [always];
 
NO LOG选项用于指定在日志中排除哪些列。
在命名日志组中,至少存在一个无”NO LOG“的定长列。比如,对LONG列使用 no log选项,可以在更改LONG列时,记录其他列的内容(LONG列本身不能存在日志里)。
ALWAYS选项, 在更新时,日志组中的所有列都会记录在日志中。
这就是所谓的”无条件“日志组,有时也叫”always log group“。如果不指定该选项,只有在日志组中的任何列被修改时,所有列才会出现在日志中。这就是所谓的”有条件“日志组。
 
说明:同一列可以在多个日志组中存在,但日志中只记录一次;同一列在“无条件”与“有条件”日志组中存在时,该列将“无条件”记录。
 
2.2,可以通过以下语句设置所有列或主键/外键/唯一键组合日志组:
语法:
alter table table_name
add supplemental log data(all,primary key,unique,foreign key) columns;
 
oracle将生成无条件或有条件日志组。对于无条件日志组,日志中将记录该日志组中的所有列;对于有条件日志组,只有日志组中的列有变化时,才会记录日志组中的所有列。
 如果指定“ALL”列,日志中将包含所有最大大小固定长度的列。这种日志是系统创建的无条件日志组。
如果指定“PRIMARY KEY”列,只要有更新,组成主键的所有列都会记录在日志中。这种日志是系统创建的无条件日志组。
Oracle使用如下顺序确定附加记录哪些列:
*组成主键的列(主键有效,或rely且非DISABLED or INITIALLY DEFERRED状态)
*最小的、至少有一个非空列的唯一索引
*记录所有标量列
如果指定“UNIQUE”列,如果任何组成唯一键或位图索引的列被修改,组成该唯一键或位图索引的其他列都会记录在日志中。这种日志是系统创建的有条件日志组。
 如果指定“FOREIGN KEY”列,如果任何组成外键的列被修改,组成该外键的其他列都会记录在日志中。这种日志是系统创建的有条件日志组。
 
2.3表级测试
drop table test;
create table test(x int,y int);
 
--增加附加日志
alter table test
add supplemental log data(all,primary key,unique,foreign key) columns;
 
select * from dba_log_groups;

OWNER                          LOG_GROUP_NAME                 TABLE_NAME                     LOG_GROUP_TYPE               ALWAYS      GENERATED
------------------------------ ------------------------------ ------------------------------ ----------------------------
SYS                            SEQ$_LOG_GRP                   SEQ$                           USER LOG GROUP               ALWAYS      USER NAME
SYS                            ENC$_LOG_GRP                   ENC$                           USER LOG GROUP               ALWAYS      USER NAME
SYS                            SYS_C0011095                   TEST                           ALL COLUMN LOGGING           ALWAYS      GENERATED NAME
SYS                            SYS_C0011096                   TEST                           PRIMARY KEY LOGGING          ALWAYS      GENERATED NAME
SYS                            SYS_C0011097                   TEST                           UNIQUE KEY LOGGING           CONDITIONAL GENERATED NAME
SYS                            SYS_C0011098                   TEST                           FOREIGN KEY LOGGING          CONDITIONAL GENERATED NAME
 
select * from dba_log_group_columns;

OWNER                          LOG_GROUP_NAME                 TABLE_NAME                     COLUMN_NAM   POSITION LOGGIN
------------------------------ ------------------------------ ------------------------------ ---------- ---------- ------
SYS                            SEQ$_LOG_GRP                   SEQ$                           OBJ#                1 LOG
SYS                            ENC$_LOG_GRP                   ENC$                           OBJ#                1 LOG
SYS                            ENC$_LOG_GRP                   ENC$                           OWNER#              2 LOG

 
--删除附加日志
alter table test
drop supplemental log data(all,primary key,unique,foreign key) columns;
 
select * from dba_log_groups;

OWNER                          LOG_GROUP_NAME                 TABLE_NAME                     LOG_GROUP_TYPE               ALWAYS      GENERATED
------------------------------ ------------------------------ ------------------------------ ----------------------------
SYS                            SEQ$_LOG_GRP                   SEQ$                           USER LOG GROUP               ALWAYS      USER NAME
SYS                            ENC$_LOG_GRP                   ENC$                           USER LOG GROUP               ALWAYS      USER NAME
 
select * from dba_log_group_columns;

OWNER                          LOG_GROUP_NAME                 TABLE_NAME                     COLUMN_NAM   POSITION LOGGIN
------------------------------ ------------------------------ ------------------------------ ---------- ---------- ------
SYS                            SEQ$_LOG_GRP                   SEQ$                           OBJ#                1 LOG
SYS                            ENC$_LOG_GRP                   ENC$                           OBJ#                1 LOG
SYS                            ENC$_LOG_GRP                   ENC$                           OWNER#              2 LOG

--增加命名附加日志
alter table test
add supplemental log group group_a(x,y);
 
select * from dba_log_groups;

OWNER                          LOG_GROUP_NAME                 TABLE_NAME                     LOG_GROUP_TYPE               ALWAYS      GENERATED
------------------------------ ------------------------------ ------------------------------ ---------------------------- ----------- --------------
SYS                            SEQ$_LOG_GRP                   SEQ$                           USER LOG GROUP               ALWAYS      USER NAME
SYS                            ENC$_LOG_GRP                   ENC$                           USER LOG GROUP               ALWAYS      USER NAME
SYS                            GROUP_A                        TEST                           USER LOG GROUP               CONDITIONAL USER NAME
 
select * from dba_log_group_columns;

OWNER                          LOG_GROUP_NAME                 TABLE_NAME                     COLUMN_NAM   POSITION LOGGIN
------------------------------ ------------------------------ ------------------------------ ---------- ---------- ------
SYS                            SEQ$_LOG_GRP                   SEQ$                           OBJ#                1 LOG
SYS                            ENC$_LOG_GRP                   ENC$                           OBJ#                1 LOG
SYS                            ENC$_LOG_GRP                   ENC$                           OWNER#              2 LOG
SYS                            GROUP_A                        TEST                           X                   1 LOG
SYS                            GROUP_A                        TEST                           Y                   2 LOG
 
alter table test
drop supplemental log group group_a;

 select * from dba_log_groups;

OWNER                          LOG_GROUP_NAME                 TABLE_NAME                     LOG_GROUP_TYPE               ALWAYS      GENERATED
------------------------------ ------------------------------ ------------------------------ ---------------------------- ----------- --------------
SYS                            SEQ$_LOG_GRP                   SEQ$                           USER LOG GROUP               ALWAYS      USER NAME
SYS                            ENC$_LOG_GRP                   ENC$                           USER LOG GROUP               ALWAYS      USER NAME

select * from dba_log_group_columns;

OWNER                          LOG_GROUP_NAME                 TABLE_NAME                     COLUMN_NAM   POSITION LOGGIN
------------------------------ ------------------------------ ------------------------------ ---------- ---------- ------
SYS                            SEQ$_LOG_GRP                   SEQ$                           OBJ#                1 LOG
SYS                            ENC$_LOG_GRP                   ENC$                           OBJ#                1 LOG
SYS                            ENC$_LOG_GRP                   ENC$                           OWNER#              2 LOG

====补充======================
 Oracle 附加日志

select supplemental_log_data_min, supplemental_log_data_pk, supplemental_log_data_ui from v$database;
如果某列的值为YES就是开了那种附加日志。
 
执行以下sql打开最小附加日志(supplemental_log_data_min)。
alter database add supplemental log data;


执行了alter database add supplemental log data;语句后需要把数据库重新启动。
 
取消附加日志
alter database drop supplemental log data;


1、10g需要激活补充日志
    select supplemental_log_data_pk,supplemental_log_data_ui from v$database;
    alter database drop supplemental log data (primary key, unique index) columns;
    alter database add supplemental log data;

2、将redo日志文件添加到logmnr分析日志列表
    exec sys.dbms_logmnr.add_logfile(logfilename=>'redo日志1', options=>sys.dbms_logmnr.new);
    exec sys.dbms_logmnr.add_logfile(logfilename=>'redo日志2', options=>sys.dbms_logmnr.addfile);
    exec sys.dbms_logmnr.add_logfile(logfilename=>'redo日志n', options=>sys.dbms_logmnr.addfile);


3、启动并分析redo日志
    exec sys.dbms_logmnr.start_logmnr(options => sys.dbms_logmnr.dict_from_online_catalog);


4、查看分析结果
    spool c:\log.txt
    select * from v$logmnr_contents ;
    spool off


5、停止logmnr
    exec sys.dbms_logmnr.end_logmnr

 
6、取消补充日志
    alter database drop supplemental log data (primary key) columns;
    alter database drop supplemental log data (unique) columns;
    alter database drop supplemental log data;

关于Oracle补充日志supplemental log的示例分析就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

您可能感兴趣的文档:

--结束END--

本文标题: Oracle补充日志supplemental log的示例分析

本文链接: https://lsjlt.com/news/65863.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Oracle补充日志supplemental log的示例分析
    这篇文章给大家介绍Oracle补充日志supplemental log的示例分析,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。 Oracle 补充日志(su...
    99+
    2024-04-02
  • SpringBoot中Log日志集成的示例分析
    这篇文章主要介绍SpringBoot中Log日志集成的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!一、日志的分类1、名字分类log4j :log for java (因为for和4读音差不多,所以交log4...
    99+
    2023-06-22
  • 使用log miner 分析oracle日志
    当我们不小心误操作致使数据库数据丢失、改变时, 需要对数据库对象做基于时间点的恢复,找到我们需要的数据,这个时间点不能认为精确确定,我们可以通过对oracle日志进行分析,而获得无操作的精确时间点。orac...
    99+
    2024-04-02
  • Linux中日志的示例分析
    这篇文章主要介绍Linux中日志的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!日志的三种类型#内核及系统日志:这种日志数据由系统服务rsyslog统一管理,根据其主配置文件/etc/rsyslog.conf...
    99+
    2023-06-27
  • sqlserver2008日志收缩的示例分析
    这篇文章主要介绍了sqlserver2008日志收缩的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。&...
    99+
    2024-04-02
  • oracle 11.2.0.4单实例打补丁的示例分析
    这篇文章主要介绍oracle 11.2.0.4单实例打补丁的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完! 0、如何获取oracle 11g安装...
    99+
    2024-04-02
  • MySQL事务日志(redo log和undo log)的详细分析
    目录前言1.redo log1.1 redo log和二进制日志的区别1.2 redo log的基本概念1.3 日志块(log block)1.4 log group和redo lo...
    99+
    2024-04-02
  • mysql中日志体系的示例分析
    这篇文章主要介绍了mysql中日志体系的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。 一、 mysql...
    99+
    2024-04-02
  • MySQL中日志记录的示例分析
    小编给大家分享一下MySQL中日志记录的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!一、SQL命令历史~/.mysql_history 记录了...
    99+
    2023-06-20
  • Spring Boot日志控制的示例分析
    这篇文章将为大家详细讲解有关Spring Boot日志控制的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。Spring Boot对日志的处理,和我们平时的日志处理完全一致,通过logback.xm...
    99+
    2023-05-30
    springboot
  • KB2565063补丁的示例分析
    这篇文章将为大家详细讲解有关KB2565063补丁的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。Windows 10 系统中勾选了设置中“更新和安全”中的“更新Windows 时提供其他Micr...
    99+
    2023-06-13
  • MySQL中死锁与日志的示例分析
    这篇文章将为大家详细讲解有关MySQL中死锁与日志的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。最近线上 MySQL 接连发生了几起数据异常,都是在凌晨爆发,由...
    99+
    2024-04-02
  • Java中springboot日志管理的示例分析
    这篇文章主要介绍了Java中springboot日志管理的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。Java是什么Java是一门面向对象编程语言,可以编写桌面应用...
    99+
    2023-06-15
  • laravel中错误与日志的示例分析
    小编给大家分享一下laravel中错误与日志的示例分析,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!日志laravel中的日志是基于monolog而封装的。laravel在它上面做了几个事情:把monolog中的addIn...
    99+
    2023-06-14
  • Linux下rsyslog日志服务的示例分析
    这篇文章主要介绍了Linux下rsyslog日志服务的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。Linux上的Syslog(系统日志协议)服务可以充当网络上的企业...
    99+
    2023-06-27
  • SecureCRT自动记录日志的示例分析
    这期内容当中小编将会给大家带来有关SecureCRT自动记录日志的示例分析,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。现在管理的数据库数量多,实时性强,经常遇到数据库突发事件,每次做的关键步骤操作我都保...
    99+
    2023-06-06
  • Mysql通用查询日志和慢查询日志的示例分析
    小编给大家分享一下Mysql通用查询日志和慢查询日志的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!MySQL中的日志包...
    99+
    2024-04-02
  • mysqldumpslow日志分析的案例
    小编给大家分享一下mysqldumpslow日志分析的案例,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!一、mysqldumpslow官方文档:http://dev.mysql.com/d...
    99+
    2024-04-02
  • MYSQL日志与备份还原的示例分析
    小编给大家分享一下MYSQL日志与备份还原的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!一、错误日志当数据库出现任何故...
    99+
    2024-04-02
  • sql server中错误日志errorlog的示例分析
    这篇文章将为大家详细讲解有关sql server中错误日志errorlog的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一 .概述SQL Server 将某些系...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作