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 ...
随机推荐
- 闲扯 Javascript 00
引言 Javascript 的作用在此就不阐述了,相信你已经知道它的用途!那我说点什么呢? 不如就和大家先扯一把,后面的工作 随后后展开吧! 首先声明:我个人对Javascript 认识,我只知道它 ...
- 分享非常有用的Java程序(关键代码)(八)---Java InputStream读取网络响应Response数据的方法!(重要)
原文:分享非常有用的Java程序(关键代码)(八)---Java InputStream读取网络响应Response数据的方法!(重要) Java InputStream读取数据问题 ======== ...
- Windows Phone 8初学者开发—第20部分:录制Wav音频文件
原文 Windows Phone 8初学者开发—第20部分:录制Wav音频文件 原文地址:http://channel9.msdn.com/Series/Windows-Phone-8-Develop ...
- MySQL主键添加/删除
2改动数据库和表的字符集alter database maildb default character set utf8;//改动数据库的字符集alter table mailtable defaul ...
- Windows的TCP协议参数
注册表编辑器:regedit 表项:HKEY_LOCAL_MACHINE\SYSTEM\CurentControlSet\Services\Tcpip\Parameters 窗口扩大因子 & ...
- ios qq 分享 失败
1. TencentOAuth 是需要调用,但QQ代码共享是没有解释.共享代码如下面: TencentOAuth *auth = [[TencentOAuth alloc] initWithAppId ...
- Swift - 获取字符串的MD5值
MD5即Message-Digest Algorithm 5(信息-摘要算法5),用于确保信息传输完整一致.是计算机广泛使用的杂凑算法之一(又译摘要算法.哈希算法),主流编程语言普遍已有MD5实现. ...
- 【通信框架】Apache的开源通信框架thrift概述
在阅读的过程中有不论什么问题.欢迎一起交流 邮箱:1494713801@qq.com QQ:1494713801 一.作用 Thrift("Scalable Cross-Languag ...
- linux: Ubuntu安装samba的问题
Ubuntu安装samba的问题 http://blog.csdn.net/jk110333/article/details/8920841 root@ubuntu:~# apt-get instal ...
- Eclipse用法和技巧二十八:Eclipse插件Easy Explore的今世
先说明一下easyexplore插件的功能,easyexplore是一个类似于 Windows Explorer的Eclipse插件,它可以帮助你在不退出Eclipse的环境下迅速浏览本地文件系统. ...