当前位置: 首页 > news >正文

深入解析下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();}

 

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

http://www.lryc.cn/news/492419.html

相关文章:

  • Elasticsearch 开放推理 API 增加了对 IBM watsonx.ai Slate 嵌入模型的支持
  • 如何搭建一个小程序:从零开始的详细指南
  • NFS搭建
  • RNN与LSTM,通过Tensorflow在手写体识别上实战
  • Docker部署FastAPI实战
  • 【Python数据分析五十个小案例】电影评分分析:使用Pandas分析电影评分数据,探索评分的分布、热门电影、用户偏好
  • Vue2学习记录
  • TMS FNC UI Pack 5.4.0 for Delphi 12
  • Redis主从架构
  • logback动态获取nacos配置
  • KETTLE安装部署V2.0
  • [RabbitMQ] 保证消息可靠性的三大机制------消息确认,持久化,发送方确认
  • aws服务--机密数据存储AWS Secrets Manager(1)介绍和使用
  • Java设计模式笔记(一)
  • Unity3d C# 实现一个基于UGUI的自适应尺寸图片查看器(含源码)
  • 【es6进阶】vue3中的数据劫持的最新实现方案的proxy的详解
  • w~视觉~3D~合集3
  • IT服务团队建设与管理
  • 一文学习开源框架OkHttp
  • 自研芯片逾十年,亚马逊云科技Graviton系列芯片全面成熟
  • Stable Diffusion 3 部署笔记
  • 微信小程序WXSS全局样式与局部样式的使用教程
  • Docker 部署 MongoDB
  • Unity图形学之法线贴图原理
  • 爬虫开发(5)如何写一个CSDN热门榜爬虫小程序
  • JVM系列之OOM观测准备
  • Qt | 开发技能提升档次哈
  • D79【 python 接口自动化学习】- python基础之HTTP
  • C++【日志模块中的writer类】前文中 循环队列用法
  • Linux:文件管理(一)——文件描述符fd