iis服务器助手广告
返回顶部
首页 > 资讯 > 数据库 >数据库日志记录模式有哪些
  • 311
分享到

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

2024-04-02 19:04:59 311人浏览 八月长安
摘要

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

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

一、日志记录模式(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 

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

您可能感兴趣的文档:

--结束END--

本文标题: 数据库日志记录模式有哪些

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

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

本篇文章演示代码以及资料文档资料下载

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

下载Word文档
猜你喜欢
  • 数据库日志记录模式有哪些
    本篇内容介绍了“数据库日志记录模式有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、日志记录模式(L...
    99+
    2024-04-02
  • java如何记录日志到数据库
    要将日志记录到数据库中,需要使用Java的数据库连接工具,如JDBC或者ORM框架(如Hibernate、MyBatis等),然后完...
    99+
    2023-08-30
    java 数据库
  • ASP网站的日志记录方式有哪些选择?
    在ASP网站开发过程中,日志记录是一个非常重要的环节。通过记录日志,我们可以监控网站的运行情况,及时排除问题,保障网站的稳定性和可靠性。那么,ASP网站的日志记录方式有哪些选择呢?本文将为您详细介绍ASP网站的日志记录方式。 使用Log...
    99+
    2023-08-20
    path 缓存 日志
  • Git日志记录的编程算法有哪些?
    Git是一种流行的版本控制工具,它能够记录你的代码更改历史,同时还能够让你追踪代码更改的详细信息。其中,Git日志记录是一种非常有用的功能,能够让你了解代码更改的时间、作者、更改内容等信息。本文将会介绍Git日志记录的编程算法以及如何使用它...
    99+
    2023-07-06
    git 日志 编程算法
  • Bash 和 ASP 中的数组日志记录技巧有哪些?
    在软件开发中,日志记录是一个非常重要的环节。通过记录程序的运行状态,可以帮助开发者快速定位问题,并且优化程序的性能。在 Bash 和 ASP 中,数组是一种非常常见的数据结构,那么如何使用数组来进行日志记录呢?本文将会介绍一些 Bash ...
    99+
    2023-07-20
    bash 日志 数组
  • 阿里云数据库日志记录删除不了
    简介 在使用阿里云数据库时,有时候我们可能会遇到无法删除日志记录的问题。本文将介绍可能导致这个问题的原因,并提供解决方法。1. 权限问题首先,检查当前用户是否有足够的权限来删除日志记录。在阿里云数据库中,只有拥有超级管理员或具有特定权限的用...
    99+
    2024-01-17
    阿里 数据库 日志
  • Shell编程中的日志记录技巧有哪些?
    Shell编程是一种非常实用的技能,它可以让你在Linux操作系统中更加高效地完成各种任务。在Shell编程中,日志记录是一个非常重要的方面。通过记录日志,你可以更好地了解程序运行的情况,及时发现问题并解决它们。本文将介绍一些Shell编...
    99+
    2023-06-04
    日志 shell 编程算法
  • Spring框架中的日志记录工具有哪些?
    Spring框架是一个非常流行的Java应用程序框架,它提供了大量的功能和工具来帮助开发人员构建高效、可靠的应用程序。其中一个重要的功能就是日志记录,Spring框架提供了多种日志记录工具来帮助开发人员记录和管理应用程序的日志信息。本文将介...
    99+
    2023-07-20
    并发 spring 日志
  • PHP API日志记录的编程技巧有哪些?
    随着互联网的发展,越来越多的应用程序需要通过API来进行数据交互。在开发API时,日志记录是一个非常重要的环节,可以帮助开发者在调试和运维过程中及时发现问题。本文将介绍PHP API日志记录的编程技巧,并结合演示代码进行详细讲解。 一、选...
    99+
    2023-10-08
    api 日志 编程算法
  • ASP 中哪些打包函数支持日志记录?
    在 ASP 中,打包函数是非常常见的。打包函数可以将多个数据打包成一个字符串或者将一个字符串解包成多个数据。在实际应用中,我们可能需要在打包或解包时记录日志,以便后续的排查和分析。那么,在 ASP 中,哪些打包函数支持日志记录呢? Se...
    99+
    2023-06-28
    打包 函数 日志
  • PHP 重定向函数有哪些常见的日志记录方法?
    在 Web 开发中,重定向是一种非常常见的操作,通过重定向,我们可以将用户引导至不同的页面,或者将请求转发至不同的地址。PHP 作为一种广泛使用的 Web 开发语言,自然也提供了多种重定向函数供开发者使用。在使用这些函数的过程中,记录日志...
    99+
    2023-08-15
    重定向 日志 函数
  • oracle数据库登录的方式有哪些
    Oracle数据库可以通过以下几种方式进行登录: SQL*Plus命令行工具:通过在命令行中输入sqlplus命令,然后输入用户...
    99+
    2024-04-02
  • ASP 日志记录的替代方案:还有哪些选择
    ASP.NET Core 日志记录框架还支持多种日志记录级别,包括调试、信息、警告、错误和致命错误。这使得您可以根据应用程序的需要选择要记录的日志信息级别。 NLog NLog 是一个跨平台的日志记录库,可以用于 .NET 核心应用程序。...
    99+
    2024-02-09
    ASP.NET Core 日志记录, 日志记录, .NET 核心
  • mysql对数据的更新操作记录日志在哪里
    这篇文章主要介绍mysql对数据的更新操作记录日志在哪里,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!mysql对数据的更新操作记录在通用查询日志和二进制日志中。通用查询日志用来记录...
    99+
    2024-04-02
  • mysql的慢查询日志记录哪些内容
    本篇内容主要讲解“mysql的慢查询日志记录哪些内容”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“mysql的慢查询日志记录哪些内容”吧! ...
    99+
    2024-04-02
  • SQL Server数据库中有哪些恢复模式
    SQL Server数据库中有哪些恢复模式,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。1.Simple 简单恢复模式,Sim...
    99+
    2024-04-02
  • oracle数据库的日志在哪
    oracle 数据库日志存储在特定位置,具体如下:重做日志文件在线重做日志文件归档日志文件sql trace 日志文件诊断日志文件需要注意,这些日志文件的位置可能因安装和配置而异。 O...
    99+
    2024-05-11
    oracle linux
  • MySQl数据库目录有哪些
    本篇文章为大家展示了MySQl数据库目录有哪些,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。1、可使用 mysqladmin 变量直接从服务器中得到数据目录路径名。...
    99+
    2024-04-02
  • 学习笔记:PHP 日志模块的使用技巧有哪些?
    在 PHP 开发过程中,日志模块是一个非常重要的组件。通过记录应用程序的运行情况,日志模块可以帮助开发人员及时发现和修复问题,提高程序的可维护性和可靠性。本文将介绍 PHP 日志模块的使用技巧,并且提供一些实用的演示代码。 一、日志模块的...
    99+
    2023-08-04
    日志 学习笔记 面试
  • Linux环境下Java程序的日志记录技巧有哪些?
    在软件开发中,日志记录是一项非常重要的技术。它可以帮助开发人员更好地了解程序的运行状态,快速定位并修复问题。Java作为一种常用的编程语言,在Linux环境下开发Java程序时,日志记录也是必不可少的。本文将介绍一些Linux环境下Jav...
    99+
    2023-08-11
    日志 linux 关键字
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作