数据块dump | |||||||||||||
|
4.利用dump函数来dump:
Date(长度 7 类型 12)
col dump_date form a35col real_date form a35
select dump(last_ddl_time) dump_date, to_char(last_ddl_time,'yyyy-mm-dd hh24:mi:ss') real_date
from user_objects
where rownum=1;
DUMP_DATE REAL_DATE ----------------------------------- --------------------- Typ=12 Len=7:
世纪 | 120 - 100 = 20 | 世纪和年份加100后存储 |
年份 | 102 - 100 = 2 | |
月份 | 4 | 月份和日期按原值存储 |
日期 | 13 | |
小时 | 16 - 1 = 15 | 时间均加1后存储 |
分钟 | 48 - 1 = 47 | |
秒 | 53 - 1 = 52 |
Number(类型 2)
长度]>,符号位/指数 数字1,数字2,数字3,......,数字20
正数:指数=数字1 - 193 (最高位为1是代表正数)
负数:指数=62 - 第一字节
数字1是最高有效位
正数:加1存储
负数:被101减,如果总长度小于21个字节,最后加一个102(是为了排序的需要)
所存储的数值计算方法为:
把下面计算的结果加起来:
每个数字乘以100^(指数-N) (N是有效位数的顺序位,第一个有效位的N=0)
例:
select dump(123456.789) from dual;
DUMP() ------------------------------- Typ=2 Len=6: ,,,,,
指数 | 195 - 193 = 2 | ||
数字1 | 13 - 1 = 12 | *1002-0 | 120000 |
数字2 | 35 - 1 = 34 | *1002-1 | 3400 |
数字3 | 57 - 1 = 56 | *1002-2 | 56 |
数字4 | 79 - 1 = 78 | *1002-3 | .78 |
数字5 | 91 - 1 = 90 | *1002-4 | .009 |
123456.789 |
select dump(-123456.789) from dual;
DUMP() ---------------------------------- Typ=2 Len=7: ,,,,,,
指数 | 62 - 60 = 2(最高位是0,代表为负数) | ||
数字1 | 101 - 89 = 12 | *1002-0 | 120000 |
数字2 | 101 - 67 = 34 | *1002-1 | 3400 |
数字3 | 101 - 45 = 56 | *1002-2 | 56 |
数字4 | 101 - 23 = 78 | *1002-3 | .78 |
数字5 | 101 - 11 = 90 | *1002-4 | .009 |
123456.789(-) |
现在再考虑一下为什么在最后加102是为了排序的需要,-123456.789在数据库中实际存储为
60,89,67,45,23,11
而-123456.78901在数据库中实际存储为
60,89,67,45,23,11,91
可见,如果不在最后加上102,在排序时会出现-123456.789的情况
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/756652/viewspace-242136/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/756652/viewspace-242136/