我的编程空间,编程开发者的网络收藏夹
学习永远不晚

数据库日志记录模式有哪些

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

数据库日志记录模式有哪些

本篇内容介绍了“数据库日志记录模式有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

一、日志记录模式(LOGGING 、FORCE LOGGING 、NOLOGGING)

    1.三者的含义

        LOGGING:当创建一个数据库对象时将记录日志信息到联机重做日志文件。LOGGING实际上是对象的一个属性,用来表示在创建对象时是否记录REDO日志,包括在做DML时是否记录REDO日志。一般表上不建议使用NOLOGGING,在创建索引或做大量数据导入时,可以使用NOLOGGING 。

        FORCE LOGGING:简言之,强制记录日志,即对数据库中的所有操作都产生日志信息,并将该信息写入到联机重做日志文件。

        NOLOGGING:正好与LOGGING、FORCE LOGGING 相反,尽可能的记录最少日志信息到联机日志文件。

        FORCE LOGGING可以在数据库级别、表空间级别进行设定、而LOGGING与NOLOGGING可以在数据对象级别设定。

        在使用DATA GUARD 时,要求使用强制记录日志模式。注:FORCE LOGGING并不比一般的LOGGING记录的日志多,数据库在FORCE LOGGING

        状态下,NOLOGGING选项将无效,因为NOLOGGING将破坏DATAGUARD的可恢复性.FORCE LOGGING强制数据库在任何状态下必须记录日志。

    2.与归档模式及非归档模式之间的关系

        日志记录模式与归档模式之间并不能等同,归档模式是指对系统产生的日志是否进行归档或不归档。

        归档模式下,将日志记录到日志文件,并进行归档。非归档模式下,同样将日志记录到日志文件,只不过不归档而已,容易丢失日志。

        日志的记录模式则不论是否处于归档或非归档,可以对日志进行记录,强制记录,或少记录日志。

        归档模式中的LOGGING或FORCE LOGGING 支持介质恢复,而NOLOGGING 模式不支持介质恢复。

        基于NOLOGGING模式操作所产生的日志远小于LOGGING模式产生的日志,即NOLOGGING模式最小化日志记录。

    3.优先级别:

        当数据库使用FORCE LOGGING时,具有最高优先级别,其次是表空间级别的FORCE LOGGING。即是当一个对象指定NOLOGGING时,而表空间或数据库级别的日志模式为FORCE LOGGING,则该选项不起作用,直到表空间或数据库级别的FORCE LOGGING解除。

        一般建议将整个数据库设置为FORCE LOGGING或基于表空间级别设定FORCE LOGGING,而不建议两者都设置为FORCE LOGGING。

        当数据库或表空间使用非强制日志模式时,则日记记录优先级别由低到高为:数据库、表空间、数据对象

二、三者的使用情况

    1.LOGGING模式

        这是日志记录的缺省模式,无论数据库是否处于归档模式,这并不改变表空间与对象级别上的缺省的日志记录模式。

        对于临时表空间将不记录日志到联机重做日志文件。

    2.NOLOGGING模式

        此模式不是不记录日志,而是最小化日志产生的数量,通常在下列情况下使用NOLOGGING

            SQL*Loader in direct mode

            INSERT ...

            CTAS

            ALTER TABLE statements (move/add/split/merge partitions)

            CREATE INDEX

            ALTER INDEX statements (move/add/split/merge partitions)

        NOLOGGING与表模式,插入模式,数据库运行模式(archived/unarchived)的关系:

        下面仅说明使用append方式插入数据时日志产生的情况,如使用下面的方式进行插入

            insert into tb_name select colnam1,colname2 from table_name;

        数据库处于归档模式

            当表模式为logging状态时,无论是否使用append模式,都会生成redo.当表模式为nologging状态时,只有append模式,不会生成redo。

        数据库处于非归档模式

            无论是在logging还是nologing的模式下,append的模式都不会生成redo,而no append模式下都会生成redo。   

    2.FORCE LOGGING模式

        设定数据库为Force Logging模式后,数据库将会记录除临时表空间或临时回滚段外所有的操作,而忽略类似NOLOGGING之类的指定参数。

        通过下面的操作来修改

            ALTER DATABASE FORCE LOGGING;

            ALTER TABLESPACE tablespace_name FORCE LOGGING;

        取消FORCE LOGGING模式

            ALTER DATABASE NO FORCE LOGGING;

            ALTER TABLESPACE tablespace_name NO FORCE LOGGING;

    3.查看不同级别的日志模式

        查看数据库级别日志的归档模式、记录模式 

        SQL> select log_mode,force_logging from v$database;

        LOG_MODE     FORCE_LOGGING

        ------------ -------------

        ARCHIVELOG   NO

        查看表空间级别的日志记录模式

        SQL> select tablespace_name,logging,force_logging from dba_tablespaces;

        TABLESPACE_NAME LOGGING   FORCE_LOGGING

        --------------- --------- -------------

        SYSTEM          LOGGING   NO

        UNDOTBS1        LOGGING   NO

        SYSAUX          LOGGING   NO

        TEMP            NOLOGGING NO

        USERS           LOGGING   NO   

        查看对象级别的日志记录模式

        scott@ORCL> select table_name,logging from user_tables;

        TABLE_NAME                     LOG

        ------------------------------ ---

        TB_A                           YES

        TB_B                           YES

    4.日志记录模式的转换

        a.数据库从非强制日子模式切换到强制日志模式

            sys@ORCL> alter database force logging;     

        b.数据库从强制日志模式切换到非强制日志模式

            sys@ORCL> alter database no force logging;

        c.表空间级别从强制日志模式切换到非强制日志模式

            sys@ORCL> alter tablespace no force logging;

        d.表空间级别从非强制日志模式切换到强制日志模式

            sys@ORCL> alter tablespace no force logging;

        e.对象级别日志记录模式

            sys@ORCL> alter table tb_a nologging;     --不记录日志模式

            sys@ORCL> alter table tb_a logging;       --采用日志记录模式

三、LOB段上有关NOLOGGING与LOGGING的情况

    计算所有LOB的大小:

       SELECT SUM(BYTES)/1024/1024/1024 as LOB_Size

       FROM user_segments 

       WHERE segment_type='LOBSEGMENT';

    计算所有nologging的大小

        SELECT SUM(s.BYTES)/1024/1024/1024 as Nologging_size

        FROM user_segments s,user_lobs l

        WHERE s.segment_type='LOBSEGMENT'

        AND l.LOGGING='NO' AND l.SEGMENT_NAME=s.SEGMENT_NAME;

    计算LOB段上nologging/logging的数量

        SELECT COUNT(*) FROM user_lobs WHERE logging='NO';

        SELECT COUNT(*) FROM user_lobs WHERE logging='YES';

四、IMPDP时不写redo

    1.关闭force logging

     alter database no force logging;

    2.关闭表logging属性

     alter table scott.t_test nologging;

    3.nologfile=Y导入

     impdp '\/ as sysdba\' dumpfile=xxx.dmp tables=scott.t_test NOLOGFILE=Y 

“数据库日志记录模式有哪些”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

数据库日志记录模式有哪些

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

java如何记录日志到数据库

要将日志记录到数据库中,需要使用Java的数据库连接工具,如JDBC或者ORM框架(如Hibernate、MyBatis等),然后完成以下步骤:1. 创建数据库表:在数据库中创建一个表来存储日志信息,包括日志级别、时间、消息等字段。2. 导
2023-08-30

如何使用PHP进行日志记录?(PHP实现日志记录的方法有哪些?)

日志记录是应用程序开发中用于记录事件、错误和调试信息的至关重要的技术。PHP提供了多种日志记录方法,每种方法都有其独特的优势和劣势。文件日志记录:简单易用,但缺乏格式化和中央日志管理。数据库日志记录:提供高级格式化和查询功能,但需要数据库服务器。Syslog日志记录:将日志信息发送到系统日志守护程序,可以将日志信息集中到一个位置。第三方库:使用第三方库简化日志记录过程,提供丰富的功能,如格式化、过滤和远程日志记录。选择最合适的日志记录方法取决于应用程序的需求。对于简单的情况,文件日志记录可能足够;对于需要
如何使用PHP进行日志记录?(PHP实现日志记录的方法有哪些?)
2024-04-02

阿里云数据库日志记录删除不了

简介在使用阿里云数据库时,有时候我们可能会遇到无法删除日志记录的问题。本文将介绍可能导致这个问题的原因,并提供解决方法。1.权限问题首先,检查当前用户是否有足够的权限来删除日志记录。在阿里云数据库中,只有拥有超级管理员或具有特定权限的用户才能执行删除操作。如果你没有足够的权限,你可以联系管理员或申请更高的权限。2.日志
阿里云数据库日志记录删除不了
2024-01-17

ASP 日志记录的替代方案:还有哪些选择

ASP.NET Core 日志记录框架是构建在 .NET 核心平台上的,它提供了一个非常灵活和易于使用的 API 来记录应用程序日志。它支持多种日志记录目标,包括文本文件、控制台、事件日志和数据库。
ASP 日志记录的替代方案:还有哪些选择
2024-02-09

如何知道数据库中哪些表没有记录

使用sp_MSForEachTable这个系统存储过程。创建一张临时表,它有2个字段,[Table_Name]和[Total_Records]。然后使用sp_MSForEachTable来处理,把结果插入上面创建的临时表中。如果Total_Records为0的
如何知道数据库中哪些表没有记录
2022-02-06

编程热搜

目录