目录

一、项目新建表、主键、索引注意事项

二、举例说明建表、主建、索引的操作方法

2.1 设定需求如下

2.2 普通表操作方法

2.3 分区表操作方法

三、表、主键、索引的常规维护操作

3.1 表结构修改的方法举例

3.2 表、主建、索引的日常维护举例

一、项目新建表、主键、索引注意事项

  • 需要显示指定表和索引所属表空间,具体语法可参考下文中的示例。
  • 表是否分区根据业务实际需求确定,一般单表数据量超过千万以上,并有周期性删除历史数据需求的表需要考虑使用分区表。
  • 如果是分区表,需要注意对应的索引是本地(local)索引。
  • 主键默认就包含了一个唯一性索引,同样需要注意所属表空间问题。
  • PL/SQL工具获取的分区表的建表语句,主建和索引部分获取不到local关键字,需要手动添加上。

二、举例说明建表、主建、索引的操作方法

下面就对上面所说的注意事项,举例说明实际建表、主建、索引的操作方法。

2.1 设定需求如下

1. 建普通表t_normal, 字段id, name, start_time, content,
设定id列为表t_normal的主建,主键名称为pk_t_normal_id,
建立id,name两列的组合索引,索引名称为idx_t_normal。 2. 建分区表t_part, 字段id, name, start_time, content,
分区字段是start_time,按天分区,
建立start_time,id两列为表t_part的主建,主键名称为pk_t_part_id,
建立start_time,id,name三列的组合索引,索引名称为idx_t_part。

2.1.1查询数据库有哪些表空间

select name from v$tablespace;

2.1.2本文档假设数据库有这两个业务用户的表空间:

DBS_D_XXX     存放数据的表空间
DBS_I_XXX 存放索引的表空间

注:新建表及其索引属于哪个表空间根据项目自己的规划自行判断。实际网优项目中用户自定义的表空间都是DBS_D开头的是存放数据,DBS_I开头的是存放索引。

2.2 普通表操作方法

2.2.1新建普通表示例

create table t_normal(
id number,
name varchar2(20),
start_time date,
content varchar2(200)
)tablespace dbs_d_xxx;

注:表示建立的t_normal表数据存放在dbs_d_xxx表空间中。

2.2.2普通表建立主建示例

alter table t_normal add constraint pk_t_normal_id primary key(id) using index tablespace dbs_i_xxx;

注:表示建立的主建pk_t_normal_id对应的唯一性索引pk_t_normal_id数据存放在dbs_i_xxx表空间中。

2.2.3普通表建立索引示例

create index idx_t_normal on t_normal(id, name) tablespace dbs_i_xxx;

注:表示建立的索引idx_t_normal数据存放在dbs_i_xxx表空间中。

2.3 分区表操作方法

项目中新建表,一般常用的分区表基本都是range分区,这里就以range分区举例说明。

2.3.1新建分区表示例

create table t_part(
id number,
name varchar2(20),
start_time date,
content varchar2(200)
)partition by range(start_time)
(
partition P20150101 values less than (TO_DATE(' 2015-01-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIAN'))
tablespace dbs_d_xxx,
partition P20150102 values less than (TO_DATE(' 2015-01-02 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIAN'))
tablespace dbs_d_xxx,
partition P20150103 values less than (TO_DATE(' 2015-01-03 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIAN'))
tablespace dbs_d_xxx
);

注:partition by range() 括号中是分区字段,下面的括号中就是包含的具体分区,每个分区都需要显示指定存放表空间名称。

上面示例建了3个分区,实际项目可能需要创建半年的分区,格式与上面一样,这里给出一个15年上半年的分区示例,便于参考。只需根据项目实际情况更改分区字段和表空间名称即可。

2.3.2分区表建立主建示例

 alter table t_part add constraint pk_t_part_id primary key(start_time, id) using index local tablespace dbs_i_xxx;

注:分区表这里多了local关键字,如果没有这个关键字,分区类操作(比如删除历史分区)会导致对应的索引失效,所以除非有特殊需求建立全局索引,否则都应该建立本地索引,即必须加上local关键字。

2.3.3分区表建立索引示例

create index idx_t_part on t_part(start_time, id, name) local tablespace dbs_i_xxx;

注:同样注意要加local关键字。

2.3.4分区表添加一个分区

alter table t_part add partition P20150104 values less than (TO_DATE(' 2015-01-04 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIAN'))
tablespace dbs_d_xxx;

注:分区表t_part添加一个分区P20150104,这里对应存放的是20150103的数据。

2.3.5分区表删除一个分区

alter table t_part drop partition P20150104;

注:分区表t_part删除分区P20150104。

三、表、主键、索引的常规维护操作

3.1 表结构修改的方法举例:

3.1.1表添加一个字段

alter table t_part add content2 varchar2(50);

注:t_part表添加字段content2 数据类型varchar2(50)

3.1.2表添加多个字段

alter table t_part add (
content3 varchar2(50),
content4 varchar2(50),
content5 varchar2(50)
);

注:t_part表添加3个字段content3, content4, content5 数据类型都为varchar2(50)

3.1.3表删除一个字段

alter table t_part drop column content5;

注:t_part表删除字段content5,一般不推荐删除表的字段。

3.1.4表删除多个字段

alter table t_part drop(content3, content4);

注:t_part表删除多个字段content3,content4,一般不推荐删除表的字段。

3.1.5表修改一个字段的数据类型

alter table t_part modify id number(7,0);

注:t_part表修改id字段的数据类型为number(7,0)

3.1.6表修改多个字段的数据类型

alter table t_part modify(
name varchar2(50),
content varchar2(50)
);

注:t_part表修改name字段的数据类型为varchar2(50), 修改content字段的数据类型为varchar2(50)

3.2 表、主建、索引的日常维护举例:

3.2.1删除表的主建

alter table t_normal drop primary key;
alter table t_part drop primary key;

注:删除普通表t_normal的主建,删除分区表t_part的主建。语法相同。

3.2.2删除表的索引

drop index idx_t_normal;
drop index idx_t_part;

注:删除普通表的普通索引,删除分区表的分区索引。语法相同。

3.2.3重建/新建表的主建

普通表t_normal建立主建:

alter table t_normal add constraint pk_t_normal_id primary key(id) using index tablespace dbs_i_xxx;

分区表t_part建立主建:

alter table t_part add constraint pk_t_part_id primary key(start_time, id) using index local tablespace dbs_i_xxx;

注:上文已经提到过,这里再次重点强调,表的主建对应了一个唯一性索引,需要明确指定这个索引的存储表空间,另外,分区表建立主建语句中要有local关键字。

若表中的数据量在百万级别以上请慎重考虑需求是否合理,大表操作请跟DBA沟通后再操作。

3.2.4重建/新建表的索引

普通表在线建立索引:

create index idx_t_normal on t_normal(id, name) tablespace dbs_i_xxx online;

分区表在线建立索引:

create index idx_t_part on t_part(start_time, id, name) local tablespace dbs_i_xxx online;

注:跟上面新建表时建立索引方法一样,只是这里多了online参数可选,加上online参数的意思是在线建立索引,可以避免创建索引过程中,影响到其他会话对此表的DML操作。

每张表的索引个数不宜超过4个,否则会对此表的入库性能有影响。

若表中的数据量在千万级别以上,且确认要新建索引,请跟DBA沟通后再操作。

Oracle基础维护02-表、主键、索引、表结构维护手册的更多相关文章

  1. iot 表 主键索引叶子块包含了表所有数据

    <pre name="code" class="html">iot表测试: 在create table语句后面使用organization inde ...

  2. 修改mysql表结构,添加一个主键索引自增字段,修改原来的主字段为普通字段

    原来有一个字段id,为自增,主键,索引.现在要新增一个字段s_id为自增,主键,索引.同时把原来的主字段改成普通字段,默认值为0. Alter table e_diamond_jhds change ...

  3. MYSQL的全表扫描,主键索引(聚集索引、第一索引),非主键索引(非聚集索引、第二索引),覆盖索引四种不同查询的分析

    文章出处:http://inter12.iteye.com/blog/1430144 MYSQL的全表扫描,主键索引(聚集索引.第一索引),非主键索引(非聚集索引.第二索引),覆盖索引四种不同查询的分 ...

  4. 删除指定表的所有索引,包括主键索引,唯一索引和普通索引 ,适用于sql server 2005,

    原文:删除指定表的所有索引,包括主键索引,唯一索引和普通索引 ,适用于sql server 2005, --删除指定表中所有索引 --用法:declare @tableName varchar(100 ...

  5. oracle 建表 主键自增序列/////

    oracle 建表 主键自增序列 (2011-10-12 11:59:22) 转载▼ 标签: 杂谈 分类: oracle SQL> create table sms_activity(  2   ...

  6. oracle 数据库 主键索引重建

    oracle 数据库 主键索引重建 alter table table_name drop primary key; alter table table_name add constraint pk_ ...

  7. Oracle + Entity Framework 更新没有设置主键的表

    最近用Entity Framework 开发的时候,发现一个问题,在默认情况下,EF不能对一个没有主键的表进行更新.插入和删除的动作. 那么,应该怎么处理没有主键的表呢? 我们打开这个表的edmx文件 ...

  8. MySQL的InnoDB表如何设计主键索引-转自淘宝MySQL经典案例

    创建a表 id主键 CREATE TABLE `a` (`id` bigint(20) NOT NULL AUTO_INCREMENT ,`message_id` int(11) NOT NULL,` ...

  9. Oracle对没有主键的表分页

    普通情况对于有主键,能够做唯一表识的表.我们能够利用主键和rownum配合实现.比如: select scott.emp.* from scott.emp left join (select empn ...

随机推荐

  1. TODO:小程序开发过程之体验者

    TODO:小程序开发过程之体验者 1. 小程序开发过程,先下载开发者并安装开发者工具,现在腾讯开放测试了,普通用户也可以登录开发者工具,如图普通用户登录为调试类型,但是只能建立无AppID的项目 如果 ...

  2. Linux CentOS 配置Tomcat环境

    一.下载Tomcat 下载Tomcat方式也有两种,可以参考我的前一篇博文Linux CentOS配置JDK环境,这边就不再赘述. 二.在Linux处理Tomcat包 1.创建tomcat文件夹 mk ...

  3. OpenCASCADE Expression Interpreter by Flex & Bison

    OpenCASCADE Expression Interpreter by Flex & Bison eryar@163.com Abstract. OpenCASCADE provide d ...

  4. C#异步编程(二)

    async和await结构 序 前篇博客异步编程系列(一) 已经介绍了何谓异步编程,这篇主要介绍怎么实现异步编程,主要通过C#5.0引入的async/await来实现. BeginInvoke和End ...

  5. javascript中的操作符详解1

    好久没有写点什么了,根据博主的技术,仍然写一点javascript新手入门文章,接下来我们一起来探讨javascript的操作符. 一.前言 javascript中有许多操作符,但是许多初学者并不理解 ...

  6. Redis简单案例(二) 网站最近的访问用户

    我们有时会在网站中看到最后的访问用户.最近的活跃用户等等诸如此类的一些信息.本文就以最后的访问用户为例, 用Redis来实现这个小功能.在这之前,我们可以先简单了解一下在oracle.sqlserve ...

  7. 张高兴的 UWP 开发笔记:横向 ListView

    ListView 默认的排列方向是纵向 ( Orientation="Vertical" ) ,但如果我们需要横向显示的 ListView 怎么办? Blend for Visua ...

  8. iOS网络4——Reachability检测网络状态

    一.整体介绍 前面已经介绍了网络访问的NSURLSession.NSURLConnection,还有网页加载有关的webview,基本满足通常的网络相关的开发. 其实在网络开发中还有比较常用的就是网络 ...

  9. keepalived 知识备注

    keepalived可用于配置nginx/lvs等负载均衡设备的双机热备. keepalived基于VRRP协议,简单的说就是两个物理路由节点(一主一备),虚拟成一个逻辑上的路由节点. 实际消息的路由 ...

  10. iOS开发系列文章(持续更新……)

    iOS开发系列的文章,内容循序渐进,包含C语言.ObjC.iOS开发以及日后要写的游戏开发和Swift编程几部分内容.文章会持续更新,希望大家多多关注,如果文章对你有帮助请点赞支持,多谢! 为了方便大 ...