Oracle数据库的表空间管理可以说是非常简单和基础的一项维护工作,但是越简单的事情就越要制定统一的规范,这样数据库的各项管理工作才会愈加的简单高效。

那么接下来,问题来了..

Q1:当我们接手一个新项目,有哪些规范可以参考?

Q2:当我们维护的是一个历史项目,有哪些需要去检查记录?

Q1:当我们接手一个新项目,有哪些规范可以参考?

可以从以下几方面来考虑:

1. 不要试图使用任何系统自带的表空间作为你的业务表空间。

包括system,sysaux,undo,users等,这是约定俗成的标准规范。

2. 数据表空间和索引表空间分开管理。

比如DBS_D_JINGYU存放数据,那么同时定义DBS_I_JINGYU存放对应表的索引。

3. 不同业务用户的表空间区分开,相同业务用户不同类数据的表空间区分开。

### 情景1:如果一个库中有多个业务,分别对应不同的业务用户,那么可以根据用户划分 ###
例如:现在有2个业务用户jingyu, ludan;
那么设计为表空间DBS_D_JINGYU存放jingyu业务用户的数据,表空间DBS_D_LUDAN存放luduan业务用户的数据。
```
create tablespace DBS_D_JINGYU;
create tablespace DBS_D_LUDAN;

create user jingyu identified by jingyu default tablespace DBS_D_JINGYU;

create user ludan identified by ludan default tablespace DBS_D_LUDAN;

grant resource, connect to jingyu, ludan;

### 情景2:如果只有一个业务用户,但业务很复杂,有不同种类的数据,则可以根据数据的种类不同划分对应的表空间。 ###
比如jingyu用户,对应默认的表空间是DBS_D_JINGYU。
另外建立几个表空间存放其他明确划分的数据。
DBS_D_CONFIG 存jingyu用户下的配置数据。
DBS_D_FACT 存jingyu用户下实际产生的业务数据。
### 小结: ###
这里的情景举例只是提供了一个思路或者说形成规范的意识。
其实实际生产中本身并没有一个通用的规范,例如:
如果实际业务量很小,数据量很小,可能就没必要分这么细致;
如果数据量很大,可能存放业务数据的部分还要根据实际业务划分的更细致;
如果业务用户非常多,但各自的数据量都很少,也没必要为每个用户都分配独立的表空间。 顺便提一句,底层存储方面现在建议直接使用Oracle ASM技术,条带化减少I/O争用和热块问题。
同时使用OMF可以使创建表空间变的非常简单,如上面的例子中创建表空间不再需要手工指定datafile和数据文件大小。
但**实际项目中为了避免自动扩展造成的空间管理过分配问题**,一般不设置自动扩展,即指定固定大小并关闭自动扩展。如下例:

假设ASM磁盘组为DATA;

创建新的表空间DBS_D_JINGYU的语句:

create tablespace DBS_D_JINGYU datafile '+DATA' size 30G autoextend off;

为表空间DBS_D_JINGYU增加一个新的30G数据文件的语句:

alter tablespace DBS_D_JINGYU add datafile '+DATA' size 30G autoextend off;

查询DATA的空间使用情况:

select name, total_mb, free_mb, USABLE_FILE_MB from v$asm_diskgroup where name='DATA';


<h1 id="2">Q2:当我们维护的是一个历史项目,有哪些需要去检查记录?</h1>
<h2 id="2.1">1. 查询表空间使用率</h2>
[【转载】Oracle 查看表空间使用率SQL脚本](http://www.cnblogs.com/jyzhao/articles/3766757.html)
<h2 id="2.2">2. 查询当前连接用户用到了哪些表空间</h2>

select tablespace_name from user_tables union

select tablespace_name from user_tab_partitions union

select tablespace_name from user_indexes union

select tablespace_name from user_ind_partitions;

<h2 id="2.3">3. 查询数据表空间中是否错误的存放了索引</h2>

select owner, segment_name, segment_type, sum(bytes)/1024/1024

   from dba_segments

 where tablespace_name = 'DBS_D_JINGYU'

 group by owner, segment_name, segment_type

 having segment_type in ('INDEX PARTITION','INDEX')

 order by 4 desc

<h2 id="2.4">4. 查询拼接出删除历史分区表的执行SQL</h2>

select c.table_name,

c.tablespace_name,

c.partition_name,

'alter table ' || c.table_name || ' drop partition ' ||

c.partition_name || ';'

from user_tab_partitions c

where c.partition_name like '%'

and c.tablespace_name = 'DBS_D_JINGYU'

order by c.table_name, c.partition_position;

注:partition_name的过滤条件自己加上。
<h2 id="2.5">5. 查询某表空间中的段所属用户、段名、段类型</h2>

select owner, segment_name, segment_type, sum(bytes)/1024/1024

  from dba_segments

 where tablespace_name = 'DBS_D_JINGYU'

 group by owner, segment_name, segment_type

 order by 4 desc

<h2 id="2.6">6. 查询表空间中数据文件的当前大小(MB),最大大小(GB),是否自动扩展</h2>

set linesize 200

col file_name for a66

select FILE_ID, FILE_NAME, TABLESPACE_NAME, BYTES/1024/1024 "MB", MAXBYTES/1024/1024/1024 "GB", AUTOEXTENSIBLE, STATUS, ONLINE_STATUS from dba_data_files;

Oracle架构设计01:表空间的管理维护规范的更多相关文章

  1. Oracle表空间的管理方式

    解释说明:表空间是一个逻辑概念:=> oracle 逻辑概念段区块管理方式: number one => tablespace number two=> segments Oracl ...

  2. Oracle 表空间的日常维护与管理

    目录 Oracle 表空间的日常维护与管理 1.创建数据表空间 2.创建临时表空间 3.创建 UNDO 表空间 4.表空间的扩展与修改大小 5.表空间重命名 6.表空间的删除 7.更改表空间的读写模式 ...

  3. oracle 基础知识(二)-表空间

    一,表空间 01,表空间? Oracle数据库是通过表空间来存储物理表的,一个数据库实例可以有N个表空间,一个表空间下可以有N张表.有了数据库,就可以创建表空间.表空间(tablespace)是数据库 ...

  4. Oracle数据库之创建表空间与用户

    Oracle数据库之创建表空间与用户 一.创建表空间 基本语法表述: CREATE TABLESPACE tablespace_name [DATAFILE datafile_spec1 [,data ...

  5. Oracle create tablespace 创建表空间语法详解

    CREATE [UNDO]  TABLESPACE tablespace_name          [DATAFILE datefile_spec1 [,datefile_spec2] ...... ...

  6. ORACLE体系结构一 (逻辑结构)-表空间、段、区和数据块

    一.Oracle的逻辑结构 Oracle的逻辑结构是一种层次结构.主要由:表空间.段.区和数据块等概念组成.逻辑结构是面向用户的,用户使用Oracle开发应用程序使用的就是逻辑结构.数据库存储层次结构 ...

  7. Oracle数据库对象(表空间/同义词/序列/视图/索引)

    数据库对象 Oracle数据库对象: 数据库对象是数据库的组成部分,常常用 CREATE 命令进行创建,可以使用 ALTER 命令修改,用 DROP 执行删除操作. 种类: (1)表空间:所有的数据对 ...

  8. 实例讲解Oracle数据库设置默认表空间问题

    实例讲解Oracle数据库设置默认表空间问题   实例讲解Oracle数据库设置默认表空间问题,阅读实例讲解Oracle数据库设置默认表空间问题,DBA们经常会遇到一个这样令人头疼的问题:不知道谁在O ...

  9. Oracle 数据库中查看表空间的2种方法

    在Oracle数据库中查看表空间使用状况是我们在实际应用中经常涉及到的,以下的内容就就是对Oracle 数据库中查看表空间使用状况时所要用到的SQL的描述,希望你能从中获得自己想要的东西. Oracl ...

随机推荐

  1. 用scikit-learn学习主成分分析(PCA)

    在主成分分析(PCA)原理总结中,我们对主成分分析(以下简称PCA)的原理做了总结,下面我们就总结下如何使用scikit-learn工具来进行PCA降维. 1. scikit-learn PCA类介绍 ...

  2. Taurus.MVC 2.2 开源发布:WebAPI 功能增强(请求跨域及Json转换)

    背景: 1:有用户反馈了关于跨域请求的问题. 2:有用户反馈了参数获取的问题. 3:JsonHelper的增强. 在综合上面的条件下,有了2.2版本的更新,也因此写了此文. 开源地址: https:/ ...

  3. 如何将VCSA添加到微软域控环境,并且实现微软域账号登陆vCenter

    v:* { } o:* { } w:* { } .shape { } p.msonormal,li.msonormal,div.msonormal { margin: 0cm; margin-bott ...

  4. ES6的一些常用特性

    由于公司的前端业务全部基于ES6开发,于是给自己开个小灶补补ES6的一些常用特性.原来打算花两天学习ES6的,结果花了3天才勉强过了一遍阮老师的ES6标准入门(水好深,ES6没学好ES7又来了...) ...

  5. 前端制作动画的几种方式(css3,js)

    制作动态的网页是是前端工程师必备的技能,很好的实现动画能够极大的提高用户体验,增强交互效果,那么动画有多少实现方式,一直对此有选择恐惧症的我就总结一下,以便在开发的时候选择最好的实现方式. 1.css ...

  6. Velocity笔记--使用Velocity获取动态Web项目名的问题

    以前使用jsp开发的时候,可以通过request很轻松的获取到根项目名,现在换到使用velocity渲染视图,因为已经不依赖servlet,request等一些类的环境,而Web项目的根项目名又不是写 ...

  7. C#通过NPOI操作Excel

    参考页面: http://www.yuanjiaocheng.net/webapi/create-crud-api-1-post.html http://www.yuanjiaocheng.net/w ...

  8. 缓存工具类CacheHelper

    代码: using System; using System.Collections.Generic; using System.Linq; using System.Text; using Syst ...

  9. 餐饮连锁公司IT信息化解决方案一

             从餐饮企业的信息化需求来说,没有哪一种解决方案能满足所有餐饮企业的信息化建设需要.不同的餐饮业态有不同的业务流程,不同业态的信息化解决方案是目前餐饮企业信息化建设急需的,这种一站式整 ...

  10. XSS 前端防火墙 —— 整装待发

    到目前为止,我们把能用前端脚本防御 XSS 的方案都列举了一遍. 尽管看起来似乎很复杂累赘,不过那些是理论探讨而已,在实际中未必要都实现.我们的目标只是为了预警,能发现问题就行,并非要做到滴水不漏的程 ...