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

server/2024/11/28 1:43:26/

    之前我们介绍了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.ppmy.cn/server/145491.html

相关文章

直接抄作业!Air780E模组LuatOS开发:位运算(bit)示例

在嵌入式开发中,位运算是一种高效且常用的操作技巧。本文将介绍如何使用Air780E模组和LuatOS进行位运算,并通过示例代码帮助读者快速上手。 一、位运算概述 位运算是一种在计算机系统中对二进制数位进行操作的运算。由于计算机内部数据的存储和处理都是…

【附录】Rust国内镜像设置

目录 前言 (1)设置环境变量 (2)安装Rust (3)设置crates镜像 前言 本节课来介绍下如何在国内高速下载安装Rust和Rust依赖,由于网络原因,我们在安装Rust和下载项目依赖时都很慢&am…

【Python-办公自动化】实现自动化输出模板表格报告

import pandas as pd import numpy as np# 定义时间范围 date_range = pd.date_range(start=2023-11-01, end=2024-10-31, freq=M

Python设计模式详解之5 —— 原型模式

Prototype 设计模式是一种创建型设计模式,它通过复制已有的实例来创建新对象,而不是通过从头实例化。这种模式非常适合对象的创建成本较高或者需要避免复杂的构造过程时使用。Prototype 模式提供了一种通过克隆来快速创建对象的方式。 1. Prototype 模式…

VMware ubuntu创建共享文件夹与Windows互传文件

1.如图1所示,点击虚拟机,点击设置; 图1 2.如图2所示,点击选项,点击共享文件夹,如图3所示,点击总是启用,点击添加; 图2 图3 3.如图4所示,出现命名共享文件夹…

民宿预定管理系统|Java|SSM|Vue| 前后端分离

【重要①】前后端源码万字文档部署文档 【重要②】正版源码有问题包售后 【包含内容】 【一】项目提供非常完整的源码注释 【二】相关技术栈文档 【三】源码讲解视频 【其它服务】 【一】可以提供远程部署安装,包扩环境 【…

【Python】Uvicorn服务器

【Python】Uvicorn服务器 1.Uvicorn介绍2. Uvicorn 的特点3. Uvicorn 和 FastAPI4. 安装 Uvicorn5. 高级功能6. 性能优化7. 安全与监控8. 部署与维护9. 结论 python官方api地址 1.Uvicorn介绍 Uvicorn 既不是一个传统的“框架”,也不是一个普通的“包”&#xff0…

Vue.js组件(5):表单回显

1 文本框回显 此组件是简单的&#xff0c;只需要使用v-model绑定props的值即可&#xff1a; 1.1 父组件 // 子组件标签与传入的数据 <project-statistics :form"project"></project-statistics>const project ref({id : 1,name : 测试项目, }) 1.2 子…