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表数据存储在主键里的更多相关文章

  1. oracle数据库建表设置自增主键

    create sequence userlogin_ID increment by 1 start with 1 minvalue 1 maxvalue 9999999999999999 nocach ...

  2. 清空表数据 mysql让主键从1开始

    TRUNCATE TABLE name 删除表中的所有行,而不记录单个行删除操作.

  3. Oracle创建表、索引、主键、字段描述

    -- 创建表 create table SX04_LBALANCE ( YEAR VARCHAR2(10) not null, PROGRAMNO VARCHAR2(40) not null, FDA ...

  4. oracle 快速备份表数据

      oracle 快速备份表数据 CreateTime--2018年2月28日17:04:50 Author:Marydon UpdateTime--2017年1月20日11:45:07 1.1.9. ...

  5. MySQL数据表中有自增长主键时如何插入数据

    原文链接:https://blog.csdn.net/RuobaiMEN/article/details/79794199 MySQL数据库表中有自增主键ID,当用SQL插入语句中插入语句带有ID列值 ...

  6. SQL中的每一张表都必须设有主键吗

    问题描述: 公司的数据库表有时候会看到没有主键的,SQL中的每一张表都必须设有主键吗? 主键的作用: 1)保证实体的完整性: 2)加快数据库的操作速度: 3)在表中添加新记录时,数据库ACCESS会自 ...

  7. 分布式中的分库分表之后,ID 主键如何处理?

    面试题 分库分表之后,id 主键如何处理?(唯一性,排序等) 面试官心理分析 其实这是分库分表之后你必然要面对的一个问题,就是 id 咋生成?因为要是分成多个表之后,每个表都是从 1 开始累加,那肯定 ...

  8. Oracle数据库,非空约束、主键约束、外键约束、唯一约束

    非空约束:设置列时,可为空默认可为空,去掉对号之后设置数据不可为空: 唯一约束:在键中设置,唯一约束名称.类型Unique.列名:设置应用完成之后,此列数据具有唯一性:即数据不可重复(类型:Uniqu ...

  9. SQL修改表结构之添加主键,添加IDENTITY属性

    设计一张表时没有考虑到主键Id及自增长,现又需要,原脚本: SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TABLE [dbo].[F ...

随机推荐

  1. [转]PostgreSQL事务处理机制

    原文链接:http://blog.chinaunix.net/uid-20726500-id-4040024.html 事务的实现原理可以解读为DBMS采取何种技术确保事务的ACID特性.Postgr ...

  2. 【转】增强 scite 编辑器的代码提示功能

    在 windows 下写 Lua, 我能找到的最好的编辑器就是 luaForWindows 项目里带的 scite. npp (即 notepad++ ) 也将就着能用, 不过只有代码高亮和简单的单词 ...

  3. Quartz中文文档使用

    Quartz中文使用说明文档,内容相当详细,有需要的码友们可以看看!! 好东西要分享!! 下面是文档的内容目录,附上下载的地址:点击打开链接,下载文档 中文版目录总汇及内容提要 第一章. 企业应用中的 ...

  4. 1、Zookeeper熟悉和用途综述

    集群 配置: 192.168.32.80 192.168.32.81 192.168.32.82 server 1: zjtest7-redis:/opt/zookeeper/conf# cat zo ...

  5. 如何在Eclipse配置Tomcat服务器

    链接地址:http://jingyan.baidu.com/article/3065b3b6efa9d7becff8a4c6.html 要想在Eclipse运行jsp文件,首先需要指定对应的服务器,即 ...

  6. 极限挑战—C#+ODP 100万条数据导入Oracle数据库仅用不到1秒

    链接地址:http://www.cnblogs.com/armyfai/p/4646213.html 要:在这里我们将看到的是C#中利用ODP实现在Oracle数据库中瞬间导入百万级数据,这对快速批量 ...

  7. 基于visual Studio2013解决面试题之1306奇偶位数交换

     题目

  8. 基于visual Studio2013解决面试题之1203转16进制输出

     题目

  9. EasyUI - Messager消息框

    全局设定: JavaScript代码: //设置按钮中的文字,默认是-ok/cancel ,可以任意设置文字,比如现在的-确认/取消 $.messager.defaults = { ok: '确认', ...

  10. Linux Kbuild工作原理分析(以DVSDK生成PowerVR显卡内核模块为例)

    一.引文 前篇博文<Makefile之Linux内核模块的Makefile写法分析>,介绍了Linux编译生成内核驱动模块的Makefile的写法,但最近在DVSDK下使用Linux2.6 ...