ORCLE删除数据库文件

2024-05-28 16:20
文章标签 数据库 删除 orcle

本文主要是介绍ORCLE删除数据库文件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在实际操作中很少会去删除数据库文件,但是凡事都有例外,由于一些特殊原因,例如存储方式变化、磁盘空间不够等,需要调整和删除一些无效的数据库文件,本文介绍一下实践出来的一种删除数据库文件的操作方式。
删除前请对数据进行备份,以防出现意外。

一、操作环境

数据库版本:Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - 64bit Production

操作系统:Windows Server 12

二、操作步骤

1、查询数据库文件

查询数据库包含的数据库文件,获取数据库文件的id

select file#,name from v$datafile;

在这里插入图片描述
这里的FILE#即为数据库文件的id

2、新建表空间

新建一个表空间并使用新的数据库文件,主要是用来转移原数据库文件上的存储内容

create tablespace mytablespace datafile 'c:\mytablespace.dbf' size 100m aotuextend ON next 10m;

创建的表空间为mytablespace ,下面的语句注意替换为自己新建的表空间名字

3、查询文件包含内容

查询要删除的数据库文件是否包含有内容,如果有的话需要转移到其他表空间上

--需移动的表数据
select DISTINCT 'alter table '|| owner||'.'||segment_name || ' move tablespace mytablespace;' from dba_extents where segment_type='TABLE' and file_id=13;
--需移动的索引数据
select DISTINCT 'alter index '|| owner||'.'|| segment_name || ' rebuild tablespace mytablespace;' from dba_extents where segment_type='INDEX' and file_id=13;
--需移动的分区表数据
select DISTINCT 'alter table '|| owner||'.'|| segment_name || ' move partition '|| partition_name || ' tablespace mytablespace;' from dba_extents where segment_type='TABLE PARTITION' and file_id=13;
--需移动的分区表索引数据
select DISTINCT 'alter index '|| owner||'.'|| segment_name || ' rebuild partition '|| partition_name || ' tablespace mytablespace;' from dba_extents where segment_type='INDEX PARTITION' and file_id=13;

已上SQL查询后会显示出来该数据文件包含的内容(只查询了表和索引情况),第一列的内容可以直接拷贝出来执行,执行后会把当前数据库文件存储的内容转移到新的表空间上。

4、删除数据库文件

ALTER TABLESPACE "USERS" DROP DATAFILE 'C:\XXX\USERS_170312.DBF';
ALTER TABLESPACE USERS DROP DATAFILE 12;

已上SQL选择一个执行即可,少做等待,等ORACLE删除文件。

5、物理删除文件

将要删除的物理文件,从磁盘上删除。建议先移动到一个临时位置,过一段时间在删除。

三、出现的问题

1、重建索引

表和索引移动后,索引会失效,需要对索引进行重建,建议在业务空闲时进行移动操作。
查询失效索引:

SELECT owner,table_name,index_name,status'alter INDEX ' || index_NAME || '  REBUILD ONLINE tablespace mytablespace;'FROM dba_indexesWHERE STATUS != 'VALID'AND OWNER = 'XXX';

注意mytablespace 和XXX,mytablespace 为上面新建的表空间,XXX为数据库用户名。

2、无法移除文件

在执行第5步是可能提示文件占用无法移除,可以等一段时间再操作。有时候在执行第4步时,ORACL能自己移除文件,有时候不能。目前发现的规律是小的文件(2G左右)可以自己移除,大文件(32G)不行。

这篇关于ORCLE删除数据库文件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1011071

相关文章

SpringBoot使用Jasypt对YML文件配置内容加密的方法(数据库密码加密)

《SpringBoot使用Jasypt对YML文件配置内容加密的方法(数据库密码加密)》本文介绍了如何在SpringBoot项目中使用Jasypt对application.yml文件中的敏感信息(如数... 目录SpringBoot使用Jasypt对YML文件配置内容进行加密(例:数据库密码加密)前言一、J

shell脚本自动删除30天以前的文件(最新推荐)

《shell脚本自动删除30天以前的文件(最新推荐)》该文章介绍了如何使用Shell脚本自动删除指定目录下30天以前的文件,并通过crontab设置定时任务,此外,还提供了如何使用Shell脚本删除E... 目录shell脚本自动删除30天以前的文件linux按照日期定时删除elasticsearch索引s

Python调用Orator ORM进行数据库操作

《Python调用OratorORM进行数据库操作》OratorORM是一个功能丰富且灵活的PythonORM库,旨在简化数据库操作,它支持多种数据库并提供了简洁且直观的API,下面我们就... 目录Orator ORM 主要特点安装使用示例总结Orator ORM 是一个功能丰富且灵活的 python O

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

docker如何删除悬空镜像

《docker如何删除悬空镜像》文章介绍了如何使用Docker命令删除悬空镜像,以提高服务器空间利用率,通过使用dockerimage命令结合filter和awk工具,可以过滤出没有Tag的镜像,并将... 目录docChina编程ker删除悬空镜像前言悬空镜像docker官方提供的方式自定义方式总结docker

使用Navicat工具比对两个数据库所有表结构的差异案例详解

《使用Navicat工具比对两个数据库所有表结构的差异案例详解》:本文主要介绍如何使用Navicat工具对比两个数据库test_old和test_new,并生成相应的DDLSQL语句,以便将te... 目录概要案例一、如图两个数据库test_old和test_new进行比较:二、开始比较总结概要公司存在多

MySQL数据库函数之JSON_EXTRACT示例代码

《MySQL数据库函数之JSON_EXTRACT示例代码》:本文主要介绍MySQL数据库函数之JSON_EXTRACT的相关资料,JSON_EXTRACT()函数用于从JSON文档中提取值,支持对... 目录前言基本语法路径表达式示例示例 1: 提取简单值示例 2: 提取嵌套值示例 3: 提取数组中的值注意

查询SQL Server数据库服务器IP地址的多种有效方法

《查询SQLServer数据库服务器IP地址的多种有效方法》作为数据库管理员或开发人员,了解如何查询SQLServer数据库服务器的IP地址是一项重要技能,本文将介绍几种简单而有效的方法,帮助你轻松... 目录使用T-SQL查询方法1:使用系统函数方法2:使用系统视图使用SQL Server Configu

使用Python在Excel中插入、修改、提取和删除超链接

《使用Python在Excel中插入、修改、提取和删除超链接》超链接是Excel中的常用功能,通过点击超链接可以快速跳转到外部网站、本地文件或工作表中的特定单元格,有效提升数据访问的效率和用户体验,这... 目录引言使用工具python在Excel中插入超链接Python修改Excel中的超链接Python

SQL Server数据库迁移到MySQL的完整指南

《SQLServer数据库迁移到MySQL的完整指南》在企业应用开发中,数据库迁移是一个常见的需求,随着业务的发展,企业可能会从SQLServer转向MySQL,原因可能是成本、性能、跨平台兼容性等... 目录一、迁移前的准备工作1.1 确定迁移范围1.2 评估兼容性1.3 备份数据二、迁移工具的选择2.1