原创浅析Rowid在Oracle数据库中的应用

摘要:Oracle数据库作为目前最流行的数据库之一,被越來越多的应用于各种项目,jfuOracle中数据记录的实际物理存储问题也日益被我们所关注。文章介绍了Oracle中用来惟—•标识存储记录的Rowid伪列,并对Rowid的显示形式及内部存储作了简要的说明。中国论文网关键词:Oracle;Rowid;对象;文件;块中图分类号:TP311文献标识码:A文章编号:1009-3044(2012)09-1979-03ABriefAnalysisoftheRowidOracleDatabaseApplicationHUANGYan(JiangsuRadio&TVUniversity,Nanjing210036,China)Abstuct:TheOracledatabaseasoneofthemostpopulardatabtises,ismoreandmoreusedinvariousprojects,andtheOracleddtarecordintheactualphysicalst()rageissuesai'ealsoincreasinglybeingourconcern.ThispaperintroducesOracletouniqueidentifierstoredrecordRowiclpseudocolumns,andontheRowiddisplayformandinternalstorageasabriefdescription.Keywords:Oracle;Rowid;object;file;block1Oracle数据库OracleDatabase,又名OracleRDBMS,简称Oracle□是甲骨文公司的—款以高级结构化杳询语言(SQL)为基础的大型关系数据库管理系统,它采用方便进行逻辑管理的语言对大量有规律数据集合进行处理,是目前最流行的客户/服务器(C/S)体系结构的数据库系统之一。它的产品除了数据库系统外,还有应用系统、开发工具等。Oracle的特点主要有以下几个方面:1)采用对象/关系模型,易于数据库的建立;2)数据库服务器系统的具有动态可伸缩性;3)系统的具有高可用性和易用性:4)系统的可管理性和数据安全功能,提供了基于角色分工的安全保密管理。在数据库管理功能、完整性检查、安全性、一致性方面都有良好的表现;5)提供了新的分布式数据库能力。可通过网络较方便地读写远端数据库里的数据,并有对称复制的技术;6)对多平台的支持与开放性。2Rowid的概念Rowid(Agloballyuniqueaddressforatowinadatabase),是Oracle数据库的—•个伪列(伪列指的是这一•列本身在数据字典中实际上并不存在,在查询结果输出时被构造出来的列),是数据记录在Oracle中的惟一标识。在建立数据衣的同时数据库会自动为每个衣建立Rowid列,用来惟一标识每一条记录。它存储每条记录的实际物理地址,对记录的访问一般都是基于Rowid的。在Oracle中有三利|Rowid:foreignRowid、logicalRowid、physicalRowid□ForeignRowid即外部Rowid,它是Oracle数据库和其他数据库进行交互吋用于唯一标识其他数据库中一条记录。LogicalRowid即逻辑Rowid,用于索引组织表的辅助索引中。逻辑Rowid由逻辑主键和索引创建时记录的物理信息两部分构成。PhysicalRowid即物理Rowid,就是我们常说的Rowid,分为扩展Rowid和约束Rowid两种格式,由于约束Rowid是在0racle7及以下版本中使用的,从OracleS开始使用扩展Rowid,约束Rowid仅仅是为了对早期版本的兼容,所以该文的提到物理Rowid-*般是指扩展Rowid格式。3Rowid的显示形式一个Rowid包含关于对象、文件、块和该块中的行的基本信息。我们可通过运用select语句从Rowid伪列里杳询相应记录的Rowid,它是一个基于base64编码的数据,一共有18位,分为4部分,其显示形成如下:000000FFFBBBBBBRRR其中:000000:六位农示数据对彖编号(data_objcct_id),根据对象ID可以确定segment的值。FFF:三位表示相关文件编号,可确定datafileoBBBBBB:六位表示块编号(data_block_number)0RRR:三位表示行编号(townumber)。下面,我们举例说明一下如何从Rowid的提収相应的信息。首先,我们建立一张数据表并存储相应数据。createtablespacetestdatafile'd:\testOl.dbf'size2mcreatetabletestRowid(idnumber,namevarchar2(10),rowIDRowid)tablespacetestinsertintotest_Rowidvalues(1,AAAAA',null)insertintotest_Rowidvalues(2,'BBBBB',null)select*fromtest_Rowid其次,通过杳询语句查看记录的Rowid的值,并写入数据表的相应字段ROW.TD中。updatetest_Rowidsetrow_ID=Rowidselect*fromtest_Rowid以第一条记录为例,我们分解一下,可以看到:Datci_Object_ID=AAALMpFile=AAFBlock=AAAAAORow二AAA山于我们得到的Rowid是64进制的,所以要进行相应的进制转换。64进制...

1、当您付费下载文档后,您只拥有了使用权限,并不意味着购买了版权,文档只能用于自身使用,不得用于其他商业用途(如 [转卖]进行直接盈利或[编辑后售卖]进行间接盈利)。
2、本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供参考,付费前请自行鉴别。
3、如文档内容存在侵犯商业秘密、侵犯著作权等,请点击“举报”。

常见问题具体如下:

1、问:已经付过费的文档可以多次下载吗?

      答:可以。登陆您已经付过费的账号,付过费的文档可以免费进行多次下载。

2、问:已经付过费的文档不知下载到什么地方去了?

     答:电脑端-浏览器下载列表里可以找到;手机端-文件管理或下载里可以找到。

            如以上两种方式都没有找到,请提供您的交易单号或截图及接收文档的邮箱等有效信息,发送到客服邮箱,客服经核实后,会将您已经付过费的文档即时发到您邮箱。

注:微信交易号是以“420000”开头的28位数字;

       支付宝交易号是以“2024XXXX”交易日期开头的28位数字。

客服邮箱:

biganzikefu@outlook.com

所有的文档都被视为“模板”,用于写作参考,下载前须认真查看,确认无误后再购买;

文档大部份都是可以预览的,笔杆子文库无法对文档的真实性、完整性、准确性以及专业性等问题提供审核和保证,请慎重购买;

文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为依据;

如果您还有什么不清楚的或需要我们协助,可以联系客服邮箱:

biganzikefu@outlook.com

常见问题具体如下:

1、问:已经付过费的文档可以多次下载吗?

      答:可以。登陆您已经付过费的账号,付过费的文档可以免费进行多次下载。

2、问:已经付过费的文档不知下载到什么地方去了?

     答:电脑端-浏览器下载列表里可以找到;手机端-文件管理或下载里可以找到。

            如以上两种方式都没有找到,请提供您的交易单号或截图及接收文档的邮箱等有效信息,发送到客服邮箱,客服经核实后,会将您已经付过费的文档即时发到您邮箱。

注:微信交易号是以“420000”开头的28位数字;

       支付宝交易号是以“2024XXXX”交易日期开头的28位数字。

文秘专家
机构认证
内容提供者

1

确认删除?