Oracle表概念
对于初学者来说,对表的概念也有一定的认识。因为我们对数据库的操作,90%以上是对表的操作。
常见表的规则表(Regular table),严格意义上来说又叫 heap table(堆表),也就是我们最普通的一张表。
partition talbe、Index-organized table、Cluster 三种表类型。
partition Table :
如果一张表非常大,里面存储了几千万条、上亿条记录,那么对这一张表进行操作,效率就非常低了。分区表是将大表的数据分成称为分区的许多小的子集。假如一张表是存放中国人口信息的表,那么这么多条记录是有规律的,可以基于某一个字段将其分开。那么可以根据省级行政区可以划分 个分区,每个分区实际上就是一个独立的表,但在逻辑上这些分区又同属于一张表。
如果一张表是普通的表,只点一个 segments;如果一张表是 partition 的表,可能占多个 segments。
Index-organized table :
索引组织表(IOT),就是存储在一个索引结果中的表。存储在堆中的表是无组织的(也就是说,只要有可用的空间,数据可放在任何地方)。对你的应用来说,IOT 表和一个“常规”表并无差别。使用堆组织表时,我们必须为表和表主键上的索引分别留出空间。而 IOT 不存在主键的空间开销,因为索引就是数据,数据就是索引。
IOT 带来的好处不仅节约磁盘空间的占用,更重要的是大幅度降低了 I/O,减少了访问缓冲区 缓存(尽管从缓冲区缓存获取数据比硬盘要快得多,但缓冲区缓存并不是免费,而且也绝不是廉价的。每个缓冲区缓存获取都需要缓冲区缓存的多个闩(shuān),而闩是串行化设备,会限制应用的扩展能力)
Cluster :
Oracle 中普通的表称为堆表(heap table),堆表中的数据是无序存放的,往往在使用一段时间后,数据就变得非常无序。比如:索引中相同的 key 对应的数据存放在不同的 block 中,这时,如果要通过索引查询某个 key 的数据,就需要访问很多不同的 block,代价非常高。 我们发现很多表与表,他们的数据有相关性,因为我们访问一个表里的数据,往往要访问另一些表里的数据。我们可以把这些数据物理上存储在一块。
本节的重点也就是讲解普通的表。
对于一张普通的表,他的插入规则是无序,我们把数据的存储空间看成学生宿舍楼一个连一个的房间。并不是第一个来的人就一定先在第一个房间。先来的人只要发现某个房间还有床位是空的就可以入住。
那么我们如何让他变成的有序的呢?那么我可以专业创建一列来记录顺序。宿管在一楼门口发号码,进来一同学,发一个号码,上面标注几号房间几号床位。这样所有入住的同学都是有序的。
- SQL> create table test (a int,b varchar2(200) default rpad('*',200,'*'), c varchar2(200) default rpad('*',200,'*'));
- Table created.
- SQL> insert into test(a) values(1);
- 1 row created.
- SQL> insert into test(a) values(2);
- 1 row created.
- SQL> insert into test(a) values(3);--插入若干条记录
- 1 row created.
- .........
- SQL> select a from test;
- A
- ----------
- 2
- 3
- 4
- 5
- 1
- SQL>
上面查询插入的结果是无序的,如何变成的有序的呢?加上 order by
- SQL> select a from t order by a;
- A
- ----------
- 1
- 2
- 3
- 4
- 5
- SQL>
我们可以在表中添加一列用来记录行号,每添加一条数据自动加1。这样就有效保证插入有数据是有序列的。
表的字段类型划分:
Oracle 数据类型分用户自定义类型(user-defined)和内嵌类型(built-in),但我们大多时候都用内嵌类型,在极特别情况下才会用到自定义类型。
内嵌类型可以用为三大类,scalar 翻译成标量,可以理解成单一的数据类型,collection 收集, 这里可以理解为复合的类型,relationship 关系类型,类似于指针引用。而我们一般最常用的也就 是 scalar 数据类型。
Scalar 又可以分为:
字符串型 char(n)、nchar(n)、varchar2(n)、nvarchar2(n)、
数值型 number(p,s)、
日期型 data、timestamp
二进制类型 raw(n)、blog、clob、nclob、bfile、long、long raw、
记录编号 rowid、urowid
CHAR & VARCHAR2 类型存储比较:
char(n) n=1 to 2000 字节定长字符串,n 字节长,如果不指定长度,缺省为 1 个字节长(一个汉字为 2 字节)。
varchar2(n) n=1 to 4000 字节可变长的字符串,具体定义时指最大长度 n,这种数据类型可以放数字、字母以及 ASCII 码字符集(或者 EBCDIC 等数据库系统接受的字符集标准)中的所有符号。如果数据长度没有达到最大值 n,Oracle 8i/9i/10g 会根据数据大小自动调节字段长度,如果你的数据前后有空格,Oracle 8i 会自动将其删去。VARCHAR2 是最常用的数据类型。
Varchar2 相比于 char 在大数据的存储中就有效果的节约了很多空间。 Nchar、Nvarchar2 分别是 char 与 varchar2 的国际版。
表日常的一些操作
表的改变
- alter table test move tablespace test;
清空表
- truncate table test
删除表
- drop table test
- drop table test cascade constraints;
删除某列数据
- alter table test drop column comments cascade constraints checkpoint 1000;
创建表各个参数的意义:
- Create table
- create table TEST.T1
- (
- deptno NUMBER(2),
- dname VARCHAR2(14),
- loc VARCHAR2(13)
- )
- tablespace TEST
- pctfree 10 --此块空闲空间小于10%,则此块在FREELIST列表中移除
- initrans 1
- maxtrans 255
- storage
- (
- initial 64K --当前64k大小
- next 1M --下一个锻的空间
- minextents 1 --最小锻个数
- maxextents unlimited --限制最大锻个数-不限制
- );
Oracle表概念的更多相关文章
- oracle表分区、表分析及oracle数据泵文件导入导出开心版
1.先说oracle表分区是什么吧,这样吧我们来举个桃子,栗子太小,我们就不举了,我们来举个桃子. 你有500万份文件,你要把他存在磁盘上,好嘛,我们就一个文件夹,500万分文件在那儿杵着,我们想找到 ...
- Oracle表空间,用户,用户授权
一:Oracle表空间 1,Oracle表空间与SQL Server文件组对比 SQL Server的文件组(文件组包括若干MDF,NDF数据文件)对我们来说并不陌生,前段时间我在博客“怎样玩转千万级 ...
- oracle表分区详解
原文来自:http://www.cnblogs.com/leiOOlei/archive/2012/06/08/2541306.html oracle表分区详解 从以下几个方面来整理关于分区表的概念及 ...
- Oracle表空间管理
oracle表空间相关常用命令小结: 1.ALTER DATABASE SET DEFAULT BIGFILE TABLESPACE; //修改表空间数据文件类型 2.ALT ...
- 【转】Oracle 表空间与数据文件
--============================== --Oracle 表空间与数据文件 --============================== /* 一.概念 表空间:是一个或 ...
- Oracle表连接
一个普通的语句select * from t1, t2 where t1.id = t2.id and t1.name = 'a'; 这个语句在什么情况下最高效? 表连接分类: 1. 嵌套循环连接(N ...
- interview:about Oracle表空间
Oracle表空间 SQL Server数据库与Oracle数据库之间最大的区别要属表空间设计.Oracle数据库开创性地提出了表空间的设计理念,这为Oracle数据库的高性能做出了不可磨灭的贡献.可 ...
- oracle表连接------>排序合并连接(Merge Sort Join)
排序合并连接 (Sort Merge Join)是一种两个表在做连接时用排序操作(Sort)和合并操作(Merge)来得到连接结果集的连接方法. 对于排序合并连接的优缺点及适用场景例如以下: a,通常 ...
- Oracle表空间的管理方式
解释说明:表空间是一个逻辑概念:=> oracle 逻辑概念段区块管理方式: number one => tablespace number two=> segments Oracl ...
随机推荐
- 汇编call jmp理解
CALL 指令在实现转移之前, 要将返回地址存入堆栈的, 以便子程可以通过 ret 指令返回到 CALL 指令下面的指令接着运行; jmp 就没用这些事儿, 直 ...
- Gulp error in WebStorm: Failed to list gulp tasks
I have the same problem with webstorm after install a updated version of node. The solution for me i ...
- fflush函数
/*** flush.c ***/ #include<stdio.h> #include<string.h> #include<stdlib.h> int main ...
- vue中改变数组或对象,页面没做出对应的渲染
原文链接 数组更新检测 变异方法 Vue 包含一组观察数组的变异方法,所以它们也将会触发视图更新.这些方法如下: push() pop() shift() unshift() splice() sor ...
- C. Planning(贪心)
C. Planning time limit per test 1 second memory limit per test 512 megabytes input standard input ou ...
- 2016 ICPC 大连网络赛 部分题解
先讲1007,有m个人,n种石头,将n种石头分给m个人,每两个人之间要么是朋友关系,要么是敌人关系,朋友的话他们必须有一种相同颜色的石头,敌人的话他们必须所有石头的颜色都不相同.另外,一个人可以不拥有 ...
- [题解] [CQOI2007] 余数求和
题面 题解 考虑到这个等式\(a\bmod b = a - b * \lfloor\frac{a}{b}\rfloor\) 所以我们可以得到: \[ \begin{aligned} ans & ...
- LeetCode 88. 合并两个有序数组(Merge Sorted Array)
题目描述 给定两个有序整数数组 nums1 和 nums2,将 nums2 合并到 nums1 中,使得 num1 成为一个有序数组. 说明: 初始化 nums1 和 nums2 的元素数量分别为 m ...
- EBS 创建会计科目 小结
1 创建会计科目 方式(以AP发票为例) 1)在发票工作台对单张发票进行创建科目: 参考网址: https://www.cnblogs.com/bruce_zhao/p/3809493.html 备注 ...
- 开源运维自动化平台-opendevops
开源运维自动化平台-opendevops 简介 官网 | Github| 在线体验 CODO是一款为用户提供企业多混合云.自动化运维.完全开源的云管理平台. CODO前端基于Vue iview开发. ...