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 ...
随机推荐
- .NET Core系列 : 1、.NET Core 环境搭建和命令行CLI入门
2016年6月27日.NET Core & ASP.NET Core 1.0在Redhat峰会上正式发布,社区里涌现了很多文章,我也计划写个系列文章,原因是.NET Core的入门门槛相当高, ...
- Azure Service Fabric 开发环境搭建
微服务体系结构是一种将服务器应用程序构建为一组小型服务的方法,每个服务都按自己的进程运行,并通过 HTTP 和 WebSocket 等协议相互通信.每个微服务都在特定的界定上下文(每服务)中实现特定的 ...
- 从Script到Code Blocks、Code Behind到MVC、MVP、MVVM
刚过去的周五(3-14)例行地主持了技术会议,主题正好是<UI层的设计模式——从Script.Code Behind到MVC.MVP.MVVM>,是前一天晚上才定的,中午花了半小时准备了下 ...
- ASP.NET MVC5+EF6+EasyUI 后台管理系统(68)-微信公众平台开发- 资源环境准备
系列目录 前言: 本次将学习扩展企业微信公众号功能,微信公众号也是企业流量及品牌推广的主要途径,所谓工欲善其事必先利其器,调试微信必须把程序发布外网环境,导致调试速度太慢,太麻烦! 我们需要准备妥当才 ...
- 46张PPT讲述JVM体系结构、GC算法和调优
本PPT从JVM体系结构概述.GC算法.Hotspot内存管理.Hotspot垃圾回收器.调优和监控工具六大方面进行讲述.(内嵌iframe,建议使用电脑浏览) 好东西当然要分享,PPT已上传可供下载 ...
- SELECT INTO 和 INSERT INTO SELECT 两种表复制语句
Insert是T-sql中常用语句,Insert INTO table(field1,field2,...) values(value1,value2,...)这种形式的在应用程序开发中必不可少.但我 ...
- 《你不知道的JavaScript》整理(四)——原型
一.[[Prototype]] JavaScript中的对象有一个特殊的[[Prototype]]内置属性,其实就是对于其他对象的引用. var myObject = { a: 2 }; myObje ...
- AJAX 大全
本章内容: 简介 伪 AJAX 原生 AJAX XmlHttpRequest 的属性.方法.跨浏览器支持 jQuery AJAX 常用方法 跨域 AJAX JsonP CORS 简单请求.复制请求.请 ...
- 多线程 异步 beginInvoke EndInvoke 使用
有许多耗时操作时,还要响应用户操作.这时候就需要用其他线程或者异步来搞.本来是改造公司的日志组件.因为多上了个国外大区的业务到来本系统来.这个系统其他地方都好就是日志,动不动就要死给我们看.有时候寻找 ...
- django 学习第一天搭建环境
目前django版本是1.10,我学习的基础教材是 Web Development with Django Cookbook, Second Edition 搭建好配置环境 ssh免认证登录 修改一下 ...