自学内容网 自学内容网

深入解析下oracle date底层存储方式

    之前我们介绍了varchar2和char的数据库底层存储格式,今天我们介绍下date类型的数据存储格式,并通过测试程序快速获取一个日期。

一、环境搭建

1.1,创建表

    我们还是创建一个测试表t_code,并插入数据:

1.2,根据数据rowid,获取数据文件号和数据块id

二、数据存储格式导出

2.1,dump数据块

    我们先把存储数据的数据块进行dump,便于后续的存储格式比对。

2.2,dump文本数据

    我们通过oracle内置的dump函数,进行name和bj字段的底层存储数据的查看:

(16进制格式)

(10进制)

2.3,比对

    我们查看下dump数据块出来的数据,比对下前端dump函数出来的数据,对比下:

    可以看到,两边数据一样

 

三、说明

    oracle内部,date数据类型的内部代表码为12,也就是上面图中的TYP=12。根据这个内部码,oracle内部程序就知道该表该列的类型具体为什么。

    len=7,就告知了这个字段存储所占为7个字节。第一个字节:代表世纪,需要减去100获取实际值(120-100=20);第二个字节,代表年份,也需要减去100获取实际值(124-100=24);第三个字节代表月份(11);第四个字节代表天数(26);第五个字节代表小时,需要减去1获取实际值(5-1=4);第六个字节代表分钟,需要减去1获取实际值(23-1=22);第五个字节代表秒,需要减去1获取实际值(1-1=0)。

    我们写个简单的c语言程序,直接解析下上述的数据:

t_date(){
    int a[] = {120,124,11,26,5,23,1};
    int cent = a[0]-100;
    int year = a[1]-100;
    int month = a[2];
    int day = a[3];
    int hour = a[4]-1;
    int minute = a[5]-1;
    int second = a[6]-1;

    printf("获取时间为:%d%d-%d-%d %d:%d:%02d",cent,year,month,day,hour,minute,second);
}




int main() {
    t_date();

}

 

    我们测试的第一行数据,可以看到与直接的日期数据一模一样。 


原文地址:https://blog.csdn.net/tpc4289/article/details/144067360

免责声明:本站文章内容转载自网络资源,如侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!