Oracle架构设计01:表空间的管理维护规范
Oracle数据库的表空间管理可以说是非常简单和基础的一项维护工作,但是越简单的事情就越要制定统一的规范,这样数据库的各项管理工作才会愈加的简单高效。
那么接下来,问题来了..
Q1:当我们接手一个新项目,有哪些规范可以参考?
- 1. 查询表空间使用率
- 2. 查询当前连接用户用到了哪些表空间
- 3. 查询数据表空间中是否错误的存放了索引
- 4. 查询拼接出删除历史分区表的执行SQL
- 5. 查询某表空间中的段所属用户、段名、段类型
- 6. 查询表空间中数据文件的当前大小(MB),最大大小(GB),是否自动扩展
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:表空间的管理维护规范的更多相关文章
- Oracle表空间的管理方式
解释说明:表空间是一个逻辑概念:=> oracle 逻辑概念段区块管理方式: number one => tablespace number two=> segments Oracl ...
- Oracle 表空间的日常维护与管理
目录 Oracle 表空间的日常维护与管理 1.创建数据表空间 2.创建临时表空间 3.创建 UNDO 表空间 4.表空间的扩展与修改大小 5.表空间重命名 6.表空间的删除 7.更改表空间的读写模式 ...
- oracle 基础知识(二)-表空间
一,表空间 01,表空间? Oracle数据库是通过表空间来存储物理表的,一个数据库实例可以有N个表空间,一个表空间下可以有N张表.有了数据库,就可以创建表空间.表空间(tablespace)是数据库 ...
- Oracle数据库之创建表空间与用户
Oracle数据库之创建表空间与用户 一.创建表空间 基本语法表述: CREATE TABLESPACE tablespace_name [DATAFILE datafile_spec1 [,data ...
- Oracle create tablespace 创建表空间语法详解
CREATE [UNDO] TABLESPACE tablespace_name [DATAFILE datefile_spec1 [,datefile_spec2] ...... ...
- ORACLE体系结构一 (逻辑结构)-表空间、段、区和数据块
一.Oracle的逻辑结构 Oracle的逻辑结构是一种层次结构.主要由:表空间.段.区和数据块等概念组成.逻辑结构是面向用户的,用户使用Oracle开发应用程序使用的就是逻辑结构.数据库存储层次结构 ...
- Oracle数据库对象(表空间/同义词/序列/视图/索引)
数据库对象 Oracle数据库对象: 数据库对象是数据库的组成部分,常常用 CREATE 命令进行创建,可以使用 ALTER 命令修改,用 DROP 执行删除操作. 种类: (1)表空间:所有的数据对 ...
- 实例讲解Oracle数据库设置默认表空间问题
实例讲解Oracle数据库设置默认表空间问题 实例讲解Oracle数据库设置默认表空间问题,阅读实例讲解Oracle数据库设置默认表空间问题,DBA们经常会遇到一个这样令人头疼的问题:不知道谁在O ...
- Oracle 数据库中查看表空间的2种方法
在Oracle数据库中查看表空间使用状况是我们在实际应用中经常涉及到的,以下的内容就就是对Oracle 数据库中查看表空间使用状况时所要用到的SQL的描述,希望你能从中获得自己想要的东西. Oracl ...
随机推荐
- 用scikit-learn学习主成分分析(PCA)
在主成分分析(PCA)原理总结中,我们对主成分分析(以下简称PCA)的原理做了总结,下面我们就总结下如何使用scikit-learn工具来进行PCA降维. 1. scikit-learn PCA类介绍 ...
- Taurus.MVC 2.2 开源发布:WebAPI 功能增强(请求跨域及Json转换)
背景: 1:有用户反馈了关于跨域请求的问题. 2:有用户反馈了参数获取的问题. 3:JsonHelper的增强. 在综合上面的条件下,有了2.2版本的更新,也因此写了此文. 开源地址: https:/ ...
- 如何将VCSA添加到微软域控环境,并且实现微软域账号登陆vCenter
v:* { } o:* { } w:* { } .shape { } p.msonormal,li.msonormal,div.msonormal { margin: 0cm; margin-bott ...
- ES6的一些常用特性
由于公司的前端业务全部基于ES6开发,于是给自己开个小灶补补ES6的一些常用特性.原来打算花两天学习ES6的,结果花了3天才勉强过了一遍阮老师的ES6标准入门(水好深,ES6没学好ES7又来了...) ...
- 前端制作动画的几种方式(css3,js)
制作动态的网页是是前端工程师必备的技能,很好的实现动画能够极大的提高用户体验,增强交互效果,那么动画有多少实现方式,一直对此有选择恐惧症的我就总结一下,以便在开发的时候选择最好的实现方式. 1.css ...
- Velocity笔记--使用Velocity获取动态Web项目名的问题
以前使用jsp开发的时候,可以通过request很轻松的获取到根项目名,现在换到使用velocity渲染视图,因为已经不依赖servlet,request等一些类的环境,而Web项目的根项目名又不是写 ...
- C#通过NPOI操作Excel
参考页面: http://www.yuanjiaocheng.net/webapi/create-crud-api-1-post.html http://www.yuanjiaocheng.net/w ...
- 缓存工具类CacheHelper
代码: using System; using System.Collections.Generic; using System.Linq; using System.Text; using Syst ...
- 餐饮连锁公司IT信息化解决方案一
从餐饮企业的信息化需求来说,没有哪一种解决方案能满足所有餐饮企业的信息化建设需要.不同的餐饮业态有不同的业务流程,不同业态的信息化解决方案是目前餐饮企业信息化建设急需的,这种一站式整 ...
- XSS 前端防火墙 —— 整装待发
到目前为止,我们把能用前端脚本防御 XSS 的方案都列举了一遍. 尽管看起来似乎很复杂累赘,不过那些是理论探讨而已,在实际中未必要都实现.我们的目标只是为了预警,能发现问题就行,并非要做到滴水不漏的程 ...