热门标签 | HotTags
当前位置:  开发笔记 > 运维 > 正文

OracleDatabase中关于null值的存储

这里主要验证了number和varchar2两种数据类型null值的存储先来介绍一下rowpiece的结构引用官方文档的一张结构图通常情况下,不包括(clustertable和chainrow)一个rowpiece包括rowheader和columndata关于其他情况,会在以后的研究中陆续放

这里主要验证了number 和 varchar2 两种数据类型null值的存储 先来介绍一下row piece的结构 引用官方文档的一张结构图 通常情况下,不包括(cluster table 和 chain row)一个rowpiece 包括row header 和 column data 关于其他情况,会在以后的研究中陆续放

这里主要验证了number 和 varchar2 两种数据类型null值的存储

先来介绍一下row piece的结构

引用官方文档的一张结构图


通常情况下,不包括(cluster table 和 chain row)一个rowpiece 包括row header 和 column data

关于其他情况,会在以后的研究中陆续放出。

BBED> dump /v
File: /u01/apps/Oracle/oradata/david/users01.dbf(4)
Block: 531 Offsets: 8173to 8191 Dba:0x01000213
-------------------------------------------------------
3c020302 c1020353 59530444 55414c01 l<...á..SYS.DUAL.
06fbd4 l .ûÔ
<16 bytes per line>

例如:一个rowpiece的前3个字节 3c0203它表示

1个字节的flag
1个字节的lb(itl slot)
1个字节的columncount

如例中
3c=flag=00111100=--HDFL--=header+delete+first+last
02=lb itl slot 0x02
03=column count


列值信息包括:
列的长度,列的value
例如02c102
表示占用2个byte
c102 表示的是具体的值

dump 的信息 可以使用 UTL_RAW.CAST_TO_xxxx 来翻译(感谢itpub iori809的指导)


下面开始验证

首先环境为11.1.0.6 linux x64

  1. dex@FAKE> desc ts
  2. Name Null? Type
  3. ----------------------------------------------------------------- -------- --------------------------------------------
  4. ID NUMBER
  5. NAME VARCHAR2(20)
  6. COUNT NUMBER
  7. dex@FAKE> select t.*,
  8. 2 dbms_rowid.rowid_relative_fno(t.rowid) as "FNO#",
  9. 3 dbms_rowid.rowid_block_number(t.rowid) as "BLK#",
  10. 4 dbms_rowid.rowid_row_number(t.rowid) as "ROW#"
  11. 5 from dex.ts t
  12. 6 ;
  13. ID NAME COUNT FNO# BLK# ROW#
  14. ---------- -------------------- ---------- ---------- ---------- ----------
  15. 1 dd 4 31 0
  16. 2 2 4 31 1
  17. 2 3 4 31 2
  18. 4 4 31 3

建表语句:dex@FAKE> create table ts ( id number , name varchar2(20) , count number ) ;
因为表中没有使用long 类型的column,所以表中列的顺序和建表中的列的声明顺序相同。
BBED> set dba 4,31
DBA 0x0100001f (16777247 4,31)
BBED> map
File: /u01/apps/Oracle/oradata/fake/users01.dbf (4)
Block: 31 Dba:0x0100001f
------------------------------------------------------------
KTB Data Block (Table/Cluster)


struct kcbh, 20 bytes @0


struct ktbbh, 72 bytes @20


struct kdbh, 14 bytes @100


struct kdbt[1], 4 bytes @114


sb2 kdbr[3] @118


ub1 freespace[8036] @124


ub1 rowdata[28] @8160


ub4 tailchk @8188
推荐阅读
  • Docker的安全基准
    nsitionalENhttp:www.w3.orgTRxhtml1DTDxhtml1-transitional.dtd ... [详细]
  • 优化联通光猫DNS服务器设置
    本文详细介绍了如何为联通光猫配置DNS服务器地址,以提高网络解析效率和访问体验。通过智能线路解析功能,域名解析可以根据访问者的IP来源和类型进行差异化处理,从而实现更优的网络性能。 ... [详细]
  • 本周信息安全小组主要进行了CTF竞赛相关技能的学习,包括HTML和CSS的基础知识、逆向工程的初步探索以及整数溢出漏洞的学习。此外,还掌握了Linux命令行操作及互联网工作原理的基本概念。 ... [详细]
  • Linux 系统启动故障排除指南:MBR 和 GRUB 问题
    本文详细介绍了 Linux 系统启动过程中常见的 MBR 扇区和 GRUB 引导程序故障及其解决方案,涵盖从备份、模拟故障到恢复的具体步骤。 ... [详细]
  • 本文详细介绍了如何在BackTrack 5中配置和启动SSH服务,确保其正常运行,并通过Windows系统成功连接。涵盖了必要的密钥生成步骤及常见问题解决方法。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • 1.如何在运行状态查看源代码?查看函数的源代码,我们通常会使用IDE来完成。比如在PyCharm中,你可以Ctrl+鼠标点击进入函数的源代码。那如果没有IDE呢?当我们想使用一个函 ... [详细]
  • CentOS7源码编译安装MySQL5.6
    2019独角兽企业重金招聘Python工程师标准一、先在cmake官网下个最新的cmake源码包cmake官网:https:www.cmake.org如此时最新 ... [详细]
  • 本文详细介绍了 Dockerfile 的编写方法及其在网络配置中的应用,涵盖基础指令、镜像构建与发布流程,并深入探讨了 Docker 的默认网络、容器互联及自定义网络的实现。 ... [详细]
  • 掌握Linux:基础命令入门
    本章节深入浅出地介绍了Linux系统中的基本命令操作,帮助读者快速上手并理解其核心功能。 ... [详细]
  • 解决Linux系统中pygraphviz安装问题
    本文探讨了在Linux环境下安装pygraphviz时遇到的常见问题,并提供了详细的解决方案和最佳实践。 ... [详细]
  • 本文介绍了一款用于自动化部署 Linux 服务的 Bash 脚本。该脚本不仅涵盖了基本的文件复制和目录创建,还处理了系统服务的配置和启动,确保在多种 Linux 发行版上都能顺利运行。 ... [详细]
  • 在哈佛大学商学院举行的Cyberposium大会上,专家们深入探讨了开源软件的崛起及其对企业市场的影响。会议指出,开源软件不仅为企业提供了新的增长机会,还促进了软件质量的提升和创新。 ... [详细]
  • CMake跨平台开发实践
    本文介绍如何使用CMake支持不同平台的代码编译。通过一个简单的示例,我们将展示如何编写CMakeLists.txt以适应Linux和Windows平台,并实现跨平台的函数调用。 ... [详细]
author-avatar
猪猪情系qq
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有