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 ...
随机推荐
- 防御XSS攻击-encode用户输入内容的重要性
一.开场先科普下XSS 跨站脚本攻击(Cross Site Scripting),为不和层叠样式表(Cascading Style Sheets, CSS)的缩写混淆,故将跨站脚本攻击缩写为XSS.恶 ...
- 奇异值分解(SVD)原理与在降维中的应用
奇异值分解(Singular Value Decomposition,以下简称SVD)是在机器学习领域广泛应用的算法,它不光可以用于降维算法中的特征分解,还可以用于推荐系统,以及自然语言处理等领域.是 ...
- [Spring]IoC容器之进击的注解
先啰嗦两句: 第一次在博客园使用markdown编辑,感觉渲染样式差强人意,还是github的样式比较顺眼. 概述 Spring2.5 引入了注解. 于是,一个问题产生了:使用注解方式注入 JavaB ...
- .NetCore中的日志(1)日志组件解析
.NetCore中的日志(1)日志组件解析 0x00 问题的产生 日志记录功能在开发中很常用,可以记录程序运行的细节,也可以记录用户的行为.在之前开发时我一般都是用自己写的小工具来记录日志,输出目标包 ...
- JAVA回调机制(CallBack)详解
序言 最近学习java,接触到了回调机制(CallBack).初识时感觉比较混乱,而且在网上搜索到的相关的讲解,要么一言带过,要么说的比较单纯的像是给CallBack做了一个定义.当然了,我在理解了回 ...
- eclipse 快捷键大全
注:因eclipse版本.电脑配置等原因 有些快捷键可能导致不可用(遇到些许问题可在下方评论) [Ct rl+T] 搜索当前接口的实现类 1. [ALT +/] 此快捷键为用户编辑的好帮手,能为 ...
- 算法与数据结构(十六) 快速排序(Swift 3.0版)
上篇博客我们主要聊了比较高效的归并排序算法,本篇博客我们就来介绍另一种高效的排序算法:快速排序.快速排序的思想与归并排序类似,都是采用分而治之的方式进行排序的.快速排序的思想主要是取出无序序列中第一个 ...
- IteratorPattern(迭代子模式)
/** * 迭代子模式 * @author TMAC-J * 聚合:某一类对象的集合 * 迭代:行为方式,用来处理聚合 * 是一种行为模式,用于将聚合本身和操作聚合的行为分离 * Java中的COLL ...
- 海康网络摄像机YV12转换为BGR,由opencv Mat显示 (转)
我使用的是海康DS-2CD852MF-E, 200万,网络摄像机,已经比较老了,不过SDK在海康官网下载的,开发流程都差不多. 海康摄像机回调解码后的视频数据格式为YV12,顺便说一下YV12的数据格 ...
- IIS8 使用FastCGI配置PHP环境支持 过程详解
平时帮朋友们配置过一些PHP环境的服务器,但是一直使用的都是Apache HTTP+PHP,今天呢,我吧IIS+PHP配置方式给大家发一下下~呵呵. 在这里,我使用的是FastCGI模块映射的方式配置 ...