搜索
首页数据库mysql教程Oracle学习:分区表和索引

什么时候使用Oracle分区: 1、 大数据量的表,比如大于2GB。一方面2GB文件对于32位os是一个上限,另外备份时间长。 2、

   什么时候使用Oracle分区:
    1、 大数据量的表,比如大于2GB。一方面2GB文件对于32位os是一个上限,另外备份时间长。
    2、 包括历史数据的表,比如最新的数据放入到最新的分区中。典型的例子:历史表,只有当前月份的数据可以被修改,而其他月份只能read-only
    ORACLE只支持以下分区:tables, indexes on tables, materialized views, and indexes on materialized views
    分区对SQL和DML是透明的(应用程序不必知道已经作了分区),但是DDL可以对不同的分区进行管理。
    不同的分区之间必须有相同的逻辑属性,比如共同的表名,列名,数据类型,约束;
    但是可以有不同的物理属性,比如pctfree, pctused, and tablespaces.
    分区独立性:即使某些分区不可用,其他分区仍然可用。
    最多可以分成64000个分区,但是具有LONG or LONG RAW列的表不可以,,但是有CLOB or BLOB列的表可以。
    可以不用to_date函数,比如:
    alter session set nls_date_format='mm/dd/yyyy';
    CREATE TABLE sales_range
    (salesman_id NUMBER(5),
    salesman_name VARCHAR2(30),
    sales_amount NUMBER(10),
    sales_date DATE)
    PARTITION BY RANGE(sales_date)
    (
    PARTITION sales_jan2000 VALUES LESS THAN('02/01/2000'),
    PARTITION sales_feb2000 VALUES LESS THAN('03/01/2000'),
    PARTITION sales_mar2000 VALUES LESS THAN('04/01/2000'),
    PARTITION sales_apr2000 VALUES LESS THAN('05/01/2000')
    );
    Partition Key:最多16个columns,可以是nullable的
    非分区的表可以有分区或者非分区的索引;
    分区表可以有分区或者非分区的索引;
    Partitioning 方法:
    Range Partitioning
    List Partitioning
    Hash Partitioning
    Composite Partitioning
    Composite Partitioning:组合,以及 range-hash and range-list composite partitioning
    Range Partitioning:
    每个分区都有VALUES LESS THAN子句,表示这个分区小于(=)前一个分区的VALUES LESS THAN值。
    MAXVALUE定义最高的分区,他表示一个虚拟的无限大的值。这个分区包括null值。
    创建表 sales_range
    (salesman_id NUMBER(5),
    salesman_name VARCHAR2(30),
    sales_amount NUMBER(10),
    sales_date DATE)
    按范围分区(sales_date)
    (
    分区 sales_jan2000 值小于(TO_DATE('01/02/2000','DD/MM/YYYY')),
    分区 sales_feb2000 值小于(TO_DATE('01/03/2000') ,'DD/MM/YYYY')),
    分区 sales_mar2000 值小于(TO_DATE('01/04/2000','DD/MM/YYYY')),
    分区 sales_apr2000 值小于(TO_DATE) ('01/05/2000','DD/MM/YYYY')),
    PARTITION sales_2000 VALUES LESS THAN(MAXVALUE)
    );
    插入数据:
    插入 sales_range 值(1 ,2,3,to_date('21-04-2000','DD-MM-YYYY'));
    插入 sales_range 值(1,2,3,sysdate);
    选择数据:
    select * from sales_range;
    select * from sales_rangepartition(sales_apr2000);
    select * from sales_rangepartition(sales_mar2000);
    select * from sales_rangepartition(sales_2000);
   三个多个列分区:
    创建表 sales_range1
    (salesman_id NUMBER(5),
    salesman_name VARCHAR2(30),
    sales_amount NUMBER(10),
    sales_date DATE)
    按范围分区(sales_date, sales_amount)
    (
    分区 sales_jan2000 值小于(TO_DATE('01/02/2000','DD/MM/YYYY'),1000),
    分区 sales_feb2000 值小于(TO_DATE('01) /03/2000','DD/MM/YYYY'),2000),
    分区 sales_mar2000 值小于(TO_DATE('01/04/2000','DD/MM/YYYY'),3000),
    分区 sales_apr2000 值小于(TO_DATE('01/05/2000','DD/MM/YYYY'),4000),
    分区 sales_2000 值小于(MAXVALUE, MAXVALUE)
    );
    插入 sales_range1 值(1,2,500, TO_DATE('21/01/2000','DD/MM/YYYY'));
    插入 sales_range1 值(2,3,1500, sysdate);

Oracle学习:分区表和索引

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
oracle怎么查询所有索引oracle怎么查询所有索引May 13, 2022 pm 05:23 PM

方法:1、利用“select*from user_indexes where table_name=表名”语句查询表中索引;2、利用“select*from all_indexes where table_name=表名”语句查询所有索引。

什么是oracle asm什么是oracle asmApr 18, 2022 pm 04:16 PM

oracle asm指的是“自动存储管理”,是一种卷管理器,可自动管理磁盘组并提供有效的数据冗余功能;它是做为单独的Oracle实例实施和部署。asm的优势:1、配置简单、可最大化推动数据库合并的存储资源利用;2、支持BIGFILE文件等。

oracle全角怎么转半角oracle全角怎么转半角May 13, 2022 pm 03:21 PM

在oracle中,可以利用“TO_SINGLE_BYTE(String)”将全角转换为半角;“TO_SINGLE_BYTE”函数可以将参数中所有多字节字符都替换为等价的单字节字符,只有当数据库字符集同时包含多字节和单字节字符的时候有效。

Oracle怎么查询端口号Oracle怎么查询端口号May 13, 2022 am 10:10 AM

在Oracle中,可利用lsnrctl命令查询端口号,该命令是Oracle的监听命令;在启动、关闭或重启oracle监听器之前可使用该命令检查oracle监听器的状态,语法为“lsnrctl status”,结果PORT后的内容就是端口号。

oracle怎么删除sequenceoracle怎么删除sequenceMay 13, 2022 pm 03:35 PM

在oracle中,可以利用“drop sequence sequence名”来删除sequence;sequence是自动增加数字序列的意思,也就是序列号,序列号自动增加不能重置,因此需要利用drop sequence语句来删除序列。

oracle怎么查询数据类型oracle怎么查询数据类型May 13, 2022 pm 04:19 PM

在oracle中,可以利用“select ... From all_tab_columns where table_name=upper('表名') AND owner=upper('数据库登录用户名');”语句查询数据库表的数据类型。

oracle查询怎么不区分大小写oracle查询怎么不区分大小写May 10, 2022 pm 05:45 PM

方法:1、利用“LOWER(字段值)”将字段转为小写,或者利用“UPPER(字段值)”将字段转为大写;2、利用“REGEXP_LIKE(字符串,正则表达式,'i')”,当参数设置为“i”时,说明进行匹配不区分大小写。

Oracle怎么修改sessionOracle怎么修改sessionMay 13, 2022 pm 05:06 PM

方法:1、利用“alter system set sessions=修改后的数值 scope=spfile”语句修改session参数;2、修改参数之后利用“shutdown immediate – startup”语句重启服务器即可生效。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前By尊渡假赌尊渡假赌尊渡假赌

热工具

SublimeText3 英文版

SublimeText3 英文版

推荐:为Win版本,支持代码提示!

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Atom编辑器mac版下载

Atom编辑器mac版下载

最流行的的开源编辑器

MinGW - 适用于 Windows 的极简 GNU

MinGW - 适用于 Windows 的极简 GNU

这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

Dreamweaver Mac版

Dreamweaver Mac版

视觉化网页开发工具