Oracle 验证IOT表数据存储在主键里
iot表测试: 在create table语句后面使用organization index,就指定数据表创建结构是IOT。但是在不指定主键Primary Key的情况下,是不允许建表的。
create table t2 (id int primary key,a1 char(10),a2 char(10),a3 char(10))organization index; SQL> select object_name,object_type from user_objects; OBJECT_NAME OBJECT_TYPE
-------------------------------------------------------------------------------------------------------------------------------- -------------------
T1 TABLE
SYS_C0021515 SQL> select object_name,object_type from user_objects; OBJECT_NAME OBJECT_TYPE
-------------------------------------------------------------------------------------------------------------------------------- -------------------
SYS_IOT_TOP_101447 INDEX
T2 TABLE
SYS_C0021515 INDEX
T1 SQL> select segment_name,SEGMENT_TYPE,TABLESPACE_NAME,bytes,blocks,extents from user_segments; SEGMENT_NAME SEGMENT_TYPE TABLESPACE_NAME BYTES BLOCKS EXTENTS
------------------------------ ------------------ ------------------------------ ---------- ---------- ----------
SYS_C0021515 INDEX USERS 131072 16 2
SYS_IOT_TOP_101447 INDEX USERS 196608 24 3
T1 TABLE USERS 196608 24 3 可以IOT表数据都存放在索引里 SQL> select table_name,TABLESPACE_NAME,CLUSTER_NAME,IOT_NAME from user_tables; TABLE_NAME TABLESPACE_NAME CLUSTER_NAME IOT_NAME
--------------- ------------------------------ ------------------------------ ------------------------------
T2
T1 USERS SQL> select segment_name,SEGMENT_TYPE, TABLESPACE_NAME,EXTENT_ID,bytes,blocks from user_extents; SEGMENT_NAME SEGMENT_TYPE TABLESPACE_NAME EXTENT_ID BYTES BLOCKS
-------------------- ------------------ ------------------------------ ---------- ---------- ----------
T1 TABLE USERS 0 65536 8
T1 TABLE USERS 1 65536 8
T1 TABLE USERS 2 65536 8
SYS_C0021515 INDEX USERS 0 65536 8
SYS_C0021515 INDEX USERS 1 65536 8
SYS_IOT_TOP_101447 INDEX USERS 0 65536 8
SYS_IOT_TOP_101447 INDEX USERS 1 65536 8
SYS_IOT_TOP_101447 INDEX USERS 2 65536 8 已选择8行。 可以看到根本没有给t2(iot)表分配空间 SQL> set linesize 200
SQL> select object_name,object_id from user_objects; OBJECT_NAME OBJECT_ID
-------------------------------------------------------------------------------------------------------------------------------- ----------
SYS_IOT_TOP_101449 101450
T2 101449 begin
for i in 1 .. 2000
loop
insert into t2 values(i,i,i,'a'||i);
end loop
;
commit;
end; 将索引dump到trace文件中
SQL> select value from v$diag_info where name='Default Trace File'; VALUE
--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
/u01/app/oracle/diag/rdbms/oadb/oadb/trace/oadb_ora_29729.trc SQL> alter session set events 'immediate trace name treedump level 101450'; 会话已更改。 ----- begin tree dump
branch: 0x10000ab 16777387 (0: nrow: 12, level: 1)
leaf: 0x10000ac 16777388 (-1: nrow: 184 rrow: 184)
leaf: 0x10000ad 16777389 (0: nrow: 181 rrow: 181)
leaf: 0x10000ae 16777390 (1: nrow: 181 rrow: 181)
leaf: 0x10000af 16777391 (2: nrow: 181 rrow: 181)
leaf: 0x10000b4 16777396 (3: nrow: 181 rrow: 181)
leaf: 0x10000b5 16777397 (4: nrow: 181 rrow: 181)
leaf: 0x10000b6 16777398 (5: nrow: 181 rrow: 181)
leaf: 0x10000b7 16777399 (6: nrow: 181 rrow: 181)
leaf: 0x10000b0 16777392 (7: nrow: 181 rrow: 181)
leaf: 0x10000b1 16777393 (8: nrow: 181 rrow: 181)
leaf: 0x10000b2 16777394 (9: nrow: 181 rrow: 181)
leaf: 0x10000b3 16777395 (10: nrow: 6 rrow: 6)
----- end tree dump
~ SQL> select dbms_utility.data_block_address_file(16777388)fno,
dbms_utility.data_block_address_block(16777388) bkno from dual 2 ; FNO BKNO
---------- ----------
4 172 alter system dump datafile 4 block 172; dump 信息如下; tab 0, row 0, @0x1f69
tl: 47 fb: --H-FL-- lb: 0x0 cc: 4
col 0: [10] 36 31 20 20 20 20 20 20 20 20
col 1: [10] 36 31 20 20 20 20 20 20 20 20
col 2: [10] 36 31 20 20 20 20 20 20 20 20
col 3: [10] 61 36 31 20 20 20 20 20 20 20
tab 0, row 1, @0x1f3a
tl: 47 fb: --H-FL-- lb: 0x2 cc: 4
col 0: [10] 31 30 30 20 20 20 20 20 20 20
col 1: [10] 31 30 30 20 20 20 20 20 20 20
col 2: [10] 31 30 30 20 20 20 20 20 20 20
col 3: [10] 61 31 30 30 20 20 20 20 20 20
tab 0, row 2, @0x1f0b
tl: 47 fb: --H-FL-- lb: 0x2 cc: 4
col 0: [10] 31 30 31 20 20 20 20 20 20 20
col 1: [10] 31 30 31 20 20 20 20 20 20 20
col 2: [10] 31 30 31 20 20 20 20 20 20 20
col 3: [10] 61 31 30 31 20 20 20 20 20 20
tab 0, row 3, @0x1edc
tl: 47 fb: --H-FL-- lb: 0x2 cc: 4
col 0: [10] 31 30 32 20 20 20 20 20 20 20
col 1: [10] 31 30 32 20 20 20 20 20 20 20
col 2: [10] 31 30 32 20 20 20 20 20 20 20
col 3: [10] 61 31 30 32 20 20 20 20 20 20
tab 0, row 4, @0x1ead
tl: 47 fb: --H-FL-- lb: 0x2 cc: 4
col 0: [10] 31 30 33 20 20 20 20 20 20 20
col 1: [10] 31 30 33 20 20 20 20 20 20 20
col 2: [10] 31 30 33 20 20 20 20 20 20 20
col 3: [10] 61 31 30 33 20 20 20 20 20 20
tab 0, row 5, @0x1e7e
tl: 47 fb: --H-FL-- lb: 0x2 cc: 4
col 0: [10] 31 30 34 20 20 20 20 20 20 20
col 1: [10] 31 30 34 20 20 20 20 20 20 20
col 2: [10] 31 30 34 20 20 20 20 20 20 20
col 3: [10] 61 31 30 34 20 20 20 20 20 20 DECLARE
n VARCHAR2 (2000);
BEGIN
DBMS_STATS.convert_raw_value ('36', n);
DBMS_OUTPUT.put_line (n);
DBMS_STATS.convert_raw_value ('31', n);
DBMS_OUTPUT.put_line (n);
DBMS_STATS.convert_raw_value ('20', n);
DBMS_OUTPUT.put_line (n);
DBMS_STATS.convert_raw_value ('20', n);
DBMS_OUTPUT.put_line (n);
DBMS_STATS.convert_raw_value ('20', n);
DBMS_OUTPUT.put_line (n);
DBMS_STATS.convert_raw_value ('20', n);
DBMS_OUTPUT.put_line (n);
DBMS_STATS.convert_raw_value ('20', n);
DBMS_OUTPUT.put_line (n);
DBMS_STATS.convert_raw_value ('20', n);
DBMS_OUTPUT.put_line (n);
DBMS_STATS.convert_raw_value ('20', n);
DBMS_OUTPUT.put_line (n);
DBMS_STATS.convert_raw_value ('20', n);
DBMS_OUTPUT.put_line (n);
END; tab 0, row 0, @0x1f69
tl: 47 fb: --H-FL-- lb: 0x0 cc: 4
col 0: [10] 36 31 20 20 20 20 20 20 20 20 表示61
col 1: [10] 36 31 20 20 20 20 20 20 20 20 表示61
col 2: [10] 36 31 20 20 20 20 20 20 20 20 表示61
col 3: [10] 61 36 31 20 20 20 20 20 20 20 表示a61 tab 0, row 1, @0x1f3a
tl: 47 fb: --H-FL-- lb: 0x2 cc: 4
col 0: [10] 31 30 30 20 20 20 20 20 20 20 表示100
col 1: [10] 31 30 30 20 20 20 20 20 20 20 表示100
col 2: [10] 31 30 30 20 20 20 20 20 20 20 表示100
col 3: [10] 61 31 30 30 20 20 20 20 20 20 表示a100 tab 0, row 2, @0x1f0b
tl: 47 fb: --H-FL-- lb: 0x2 cc: 4
col 0: [10] 31 30 31 20 20 20 20 20 20 20 表示101
col 1: [10] 31 30 31 20 20 20 20 20 20 20 表示101
col 2: [10] 31 30 31 20 20 20 20 20 20 20 表示101
col 3: [10] 61 31 30 31 20 20 20 20 20 20 表示a101 tab 0, row 3, @0x1edc
tl: 47 fb: --H-FL-- lb: 0x2 cc: 4
col 0: [10] 31 30 32 20 20 20 20 20 20 20 表示102
col 1: [10] 31 30 32 20 20 20 20 20 20 20 表示102
col 2: [10] 31 30 32 20 20 20 20 20 20 20 表示102
col 3: [10] 61 31 30 32 20 20 20 20 20 20 表示a102 tab 0, row 4, @0x1ead
tl: 47 fb: --H-FL-- lb: 0x2 cc: 4
col 0: [10] 31 30 33 20 20 20 20 20 20 20 表示103
col 1: [10] 31 30 33 20 20 20 20 20 20 20 表示103
col 2: [10] 31 30 33 20 20 20 20 20 20 20 表示103
col 3: [10] 61 31 30 33 20 20 20 20 20 20 表示a103 tab 0, row 5, @0x1e7e
tl: 47 fb: --H-FL-- lb: 0x2 cc: 4
col 0: [10] 31 30 34 20 20 20 20 20 20 20 表示104
col 1: [10] 31 30 34 20 20 20 20 20 20 20 表示104
col 2: [10] 31 30 34 20 20 20 20 20 20 20 表示104
col 3: [10] 61 31 30 34 20 20 20 20 20 20 表示a104
Oracle 验证IOT表数据存储在主键里的更多相关文章
- oracle数据库建表设置自增主键
create sequence userlogin_ID increment by 1 start with 1 minvalue 1 maxvalue 9999999999999999 nocach ...
- 清空表数据 mysql让主键从1开始
TRUNCATE TABLE name 删除表中的所有行,而不记录单个行删除操作.
- Oracle创建表、索引、主键、字段描述
-- 创建表 create table SX04_LBALANCE ( YEAR VARCHAR2(10) not null, PROGRAMNO VARCHAR2(40) not null, FDA ...
- oracle 快速备份表数据
oracle 快速备份表数据 CreateTime--2018年2月28日17:04:50 Author:Marydon UpdateTime--2017年1月20日11:45:07 1.1.9. ...
- MySQL数据表中有自增长主键时如何插入数据
原文链接:https://blog.csdn.net/RuobaiMEN/article/details/79794199 MySQL数据库表中有自增主键ID,当用SQL插入语句中插入语句带有ID列值 ...
- SQL中的每一张表都必须设有主键吗
问题描述: 公司的数据库表有时候会看到没有主键的,SQL中的每一张表都必须设有主键吗? 主键的作用: 1)保证实体的完整性: 2)加快数据库的操作速度: 3)在表中添加新记录时,数据库ACCESS会自 ...
- 分布式中的分库分表之后,ID 主键如何处理?
面试题 分库分表之后,id 主键如何处理?(唯一性,排序等) 面试官心理分析 其实这是分库分表之后你必然要面对的一个问题,就是 id 咋生成?因为要是分成多个表之后,每个表都是从 1 开始累加,那肯定 ...
- Oracle数据库,非空约束、主键约束、外键约束、唯一约束
非空约束:设置列时,可为空默认可为空,去掉对号之后设置数据不可为空: 唯一约束:在键中设置,唯一约束名称.类型Unique.列名:设置应用完成之后,此列数据具有唯一性:即数据不可重复(类型:Uniqu ...
- SQL修改表结构之添加主键,添加IDENTITY属性
设计一张表时没有考虑到主键Id及自增长,现又需要,原脚本: SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TABLE [dbo].[F ...
随机推荐
- 14 - XML、JSON、PLIST对比和APP生命周期
XML中间的 数据表达/传输数据的语言 优点:特别强大 强大到很多平台都有基于XML的独立语言,如MXML.HTML 缺点:传输小型数据时,特别啰嗦 size / speed = time JSON ...
- Qt 状态机框架学习(没学会)
Qt状态机框架是基于状态图XML(SCXML) 实现的.从Qt4.6开始,它已经是QtCore模块的一部分.尽管它本身是蛮复杂的一套东西,但经过和Qt的事件系统(event system).信号槽(s ...
- QList 和std::list的比较
QList QList<T> 是一个Qt通用容器类.它存储一序列的值,并且提供基于索引的数据访问方法和快速的插入和删除操作. QList<T>, QLinkedList< ...
- FMXUI - UI.Dialog 示例
在 FMXUI 开源库,增加了 UI.Dialog 单元.此单元实现了跨平台的基础对话框组件.使用时引用 UI.Dialog 即可.如果需要自定义对话框的样式, 可以添加一个 TDialogStyle ...
- Python文件处理(1)
读取文件 解决方案: 最简单的就是一次性读取所有的内容放在一个大字符串中 all_the_text=open('thefile.txt').read() all_the_data=open('abin ...
- 实现浏览器遗漏的原件 jQuery.selectCheckbox
工作中遇到了一个下拉需要实现checkbox的效果,如下图 或许网上已经有实现了,但简单的功能自己实现就好了, 结构 <div class="form-control-wrap&quo ...
- c# winform 让Form去掉系统自带的关闭
在桌面系统时我们有时候想把winform 自带的关闭按钮和最大化最小化都去掉,我遇到了类似的情况,在网上一查也有很多答案,但是最后找到了一个最简单的答案,一句话的事,今天记录一下,就是让大家都简单的实 ...
- 基于visual Studio2013解决C语言竞赛题之1075大数阶乘
题目 解决代码及点评 /************************************************************************/ /* ...
- eclipse升级后Android使用JAR报错
升级ADT22以后,老项目编译时后遇到 NoDefFoundClassError 这个错误,因为项目中使用了jar文件. 遇到此问题的解决步骤: 1.项目根目录下建立 libs ,并将jar文件移入 ...
- ArcGIS制图——多图层道路压盖处理
[1] 启动ArcMap,载入各道路要素类.生成名为All-Roads的图层组,如他所看到的,符号级别绘制将对图层组内图层符号起作用: 图层组设置符号等级 [2] 在内容列表中,右 ...