iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >如何理解Oracle的INITRANS与事务
  • 718
分享到

如何理解Oracle的INITRANS与事务

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

本篇文章给大家分享的是有关如何理解oracle的INITRANS与事务,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。 Oracle的INIT

本篇文章给大家分享的是有关如何理解oracle的INITRANS与事务,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。

Oracle的INITRANS与事务

每个块都有一个块首部。这个块首部中有一个事务表。事务表中会建立一些条目来描述哪些事务将块上的哪些行/元素定。这个事务表的初始大小由对象的INITRANS 设置指定。对于表,这个值默认为2(索引的INITRANS 也默认为2)。事务表会根据需要动态扩展,最大达到MAXTRANS 个条目(假设块上有足够的自由空间)。所分配的每个事务条目需要占用块首部中的23~24 字节的存储空间。注意,对于Oracle 10g,MAXTRANS 则会忽略,所有段的MAXTRANS 都是255。

由于oracle块里有一个PCT_free的概念,即oracle会预留块大小的10%作为缓冲,当修改oracle的事务增加时,事务槽向下增长当更新oracle块的数据时,数据向上增长,PCT_free的空间被压缩。这里我们只是看INITRANS的作用,所以pctfree 0

SCOTT@hyyk> create table t3 (id int, num int ) INITRANS 1 pctfree 0 ;

SCOTT@hyyk> select TABLE_NAME,STATUS,PCT_FREE,PCT_USED,INI_TRANS,MAX_TRANS,INITIAL_EXTENT,NEXT_EXTENT,MIN_EXTENTS,MAX_EXTENTS,PCT_INCREASE from user_tables where table_name='T3';

如何理解Oracle的INITRANS与事务

可以看到pctfree 0 参数生效 这里的INITRANS初始值是1

SCOTT@hyyk> insert into t3 values(1,1) ;

SCOTT@hyyk> insert into t3 values(2,2);

SCOTT@hyyk> insert into t3 values(3,3);

SCOTT@hyyk> commit;

SCOTT@hyyk> select id,num ,dbms_rowid.rowid_relative_fno(rowid) file#, dbms_rowid.rowid_block_number(rowid) block# from T3;

    ID      NUM       FILE#     BLOCK#

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

     1        1           4    581

     2        2           4    581

     3        3           4    581

可以看到插入的三行数据都在4号文件的581块

会话1

SCOTT@hyyk> update t3 set num=11 where id =1;  //这里不提交

查看事务,可以发现已经开始一个事务,占据了一个事务槽080011007A050000

如何理解Oracle的INITRANS与事务

会话2

SCOTT@hyyk> update t3 set num=11 where id =2;

1 row updated.  //发现这里可以插入

这个事务表的初始大小由对象的INITRANS 设置指定。对于表,这个值默认为2(索引的INITRANS 也默认为2)

如何理解Oracle的INITRANS与事务再次查看事务,又开始了一个事务,事务xid 06001B0075050000

会话三

SCOTT@hyyk> update t3 set num=11 where id =3

...等待

因为事务表没有槽位

以上就是如何理解Oracle的INITRANS与事务,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注编程网数据库频道。

您可能感兴趣的文档:

--结束END--

本文标题: 如何理解Oracle的INITRANS与事务

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

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

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

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

下载Word文档
猜你喜欢
  • 如何理解Oracle的INITRANS与事务
    本篇文章给大家分享的是有关如何理解Oracle的INITRANS与事务,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。 Oracle的INIT...
    99+
    2024-04-02
  • 怎么理解Oracle事务
    本篇内容主要讲解“怎么理解Oracle事务”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么理解Oracle事务”吧!oracle事务1概述事务由一个或多个DM...
    99+
    2024-04-02
  • 如何理解HTML5的WebSocket与服务器推送事件
    本篇文章为大家展示了如何理解HTML5的WebSocket与服务器推送事件,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。WebSocketsWeb Sockets ...
    99+
    2024-04-02
  • 怎么理解oracle中的事务
    本篇内容主要讲解“怎么理解oracle中的事务”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么理解oracle中的事务”吧! 一组...
    99+
    2024-04-02
  • 如何理解MySQL中的事务
    今天就跟大家聊聊有关如何理解MySQL中的事务,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。事务又叫做TCL,全称是transaction cont...
    99+
    2024-04-02
  • 如何进行ITL与事务处理
    如何进行ITL与事务处理,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。 一、ITL与事务的关系 ITL(interested tran...
    99+
    2024-04-02
  • Java与Oracle实现事务(JDBC事务)实例详解
    Java与Oracle实现事务(JDBC事务)实例详解J2EE支持JDBC事务、JTA事务和容器事务事务,这里说一下怎样实现JDBC事务。       JDBC事务是由Connec...
    99+
    2023-05-31
    java jdbc事务 ava
  • 如何在Oracle中执行事务管理
    在Oracle中执行事务管理可以通过使用以下方法: 使用BEGIN和END语句来定义事务的开始和结束。在BEGIN和END语句之...
    99+
    2024-04-09
    Oracle
  • 如何理解Spring的Hibernate事务管理机制
    如何理解Spring的Hibernate事务管理机制,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。主要讲了Spring 声明式事务让我们从复杂的Hibernate事务处理中...
    99+
    2023-06-17
  • 如何理解分布式事务
    本篇内容主要讲解“如何理解分布式事务”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何理解分布式事务”吧!事务要说分布式事务,首先...
    99+
    2024-04-02
  • 如何深入理解Redis事务
    本篇内容主要讲解“如何深入理解Redis事务”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何深入理解Redis事务”吧!Redis可以看成NoSQL类型的数据...
    99+
    2024-04-02
  • 如何理解Spring双层事务
    这篇文章主要讲解了“如何理解Spring双层事务”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何理解Spring双层事务”吧!系统 A 调用系统 B 执行数据同步,系统 B 返回了错误提示...
    99+
    2023-06-15
  • 如何理解html5 Web SQL Database中事务处理函数transaction与executeSQL
    这篇文章主要讲解了“如何理解html5 Web SQL Database中事务处理函数transaction与executeSQL”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入...
    99+
    2024-04-02
  • 如何理解Oracle ASM启动与关闭
    本篇文章为大家展示了如何理解Oracle ASM启动与关闭,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。Oracle+ASM启动和关闭启动关闭注意事项 1 ASM实...
    99+
    2024-04-02
  • mysql事件与事务如何区分
    mysql事件与事务如何区分?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。mysql事件与事务如何区分1.事件MySQL中的事...
    99+
    2024-04-02
  • 如何理解EF Core事务提交
    本篇内容主要讲解“如何理解EF Core事务提交”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何理解EF Core事务提交”吧!控制事务可以使用 DbCont...
    99+
    2024-04-02
  • 如何理解Java分布式事务
    今天小编给大家分享一下如何理解Java分布式事务的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下...
    99+
    2024-04-02
  • 分布式事务该如何理解
    这篇文章给大家介绍分布式事务该如何理解,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。先上场景:压力测试,同时1万个买家在店铺Shang1购买东西,每个买家账户向shang1账户付钱。    &nbs...
    99+
    2023-06-02
  • 分布式事务使用Seata的AT事务模式如何理解
    分布式事务使用Seata的AT事务模式如何理解,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。项目使用了微服务,并且将一些模块进行了拆分,现在遇到了一个批量保存的场景,而且还...
    99+
    2023-06-19
  • 如何理解.Net事件
    今天就跟大家聊聊有关如何理解.Net事件,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。.NET 事件事件概述在发生其他类或对象关注的事情时,类或对象可通过事件通知它们。发送(或引发)...
    99+
    2023-06-17
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作