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 ...
随机推荐
- Android请求网络共通类——Hi_博客 Android App 开发笔记
今天 ,来分享一下 ,一个博客App的开发过程,以前也没开发过这种类型App 的经验,求大神们轻点喷. 首先我们要创建一个Andriod 项目 因为要从网络请求数据所以我们先来一个请求网络的共通类. ...
- 使用redis构建可靠分布式锁
关于分布式锁的概念,具体实现方式,直接参阅下面两个帖子,这里就不多介绍了. 分布式锁的多种实现方式 分布式锁总结 对于分布式锁的几种实现方式的优劣,这里再列举下 1. 数据库实现方式 优点:易理解 缺 ...
- 加深一下BlockingQueue的认识
认识BlockingQueue BlockingQueue是一种可以阻塞线程的队列,java中对这种队列提供了方法抽象,BlockingQueue则是抽象的接口. add:添加元素到队列里,添加成功返 ...
- 2015 西雅图微软总部MVP峰会记录
2015 西雅图微软总部MVP峰会记录 今年决定参加微软MVP全球峰会,在出发之前本人就已经写这篇博客,希望将本次会议原汁原味奉献给大家 因为这次是本人第一次写会议记录,写得不好的地方希望各位园友见谅 ...
- 使用CSS3实现一个3D相册
CSS3系列我已经写过两篇文章,感兴趣的同学可以先看一下CSS3初体验之奇技淫巧,CSS3 3D立方体效果-transform也不过如此 第一篇主要列出了一些常用或经典的CSS3技巧和方法:第二篇是一 ...
- C#多线程之线程池篇2
在上一篇C#多线程之线程池篇1中,我们主要学习了如何在线程池中调用委托以及如何在线程池中执行异步操作,在这篇中,我们将学习线程池和并行度.实现取消选项的相关知识. 三.线程池和并行度 在这一小节中,我 ...
- ASP.NET MVC开发:Web项目开发必备知识点
最近加班加点完成一个Web项目,使用Asp.net MVC开发.很久以前接触的Asp.net开发还是Aspx形式,什么Razor引擎,什么MVC还是这次开发才明白,可以算是新手. 对新手而言,那进行A ...
- Oracle数据库该如何着手优化一个SQL
这是个终极问题,因为优化本身的复杂性实在是难以总结的,很多时候优化的方法并不是用到了什么高深莫测的技术,而只是一个思想意识层面的差异,而这些都很可能连带导致性能表现上的巨大差异. 所以有时候我们应该先 ...
- Entity Framework 手动使用migration里面的up 和down方法。
add-migration -IgnoreChanges 201606100717405_201606100645298_InitialCreate 执行这一句后 ,清空使用map生成的代码,个人不太 ...
- ASP.NET Core 中文文档 第四章 MVC(4.4)依赖注入和控制器
原文: Dependency Injection and Controllers 作者: Steve Smith 翻译: 刘浩杨 校对: 孟帅洋(书缘) ASP.NET Core MVC 控制器应通过 ...