网站首页 > 技术文章 正文
修改oracle数据文件大小 报错:ORA-03297
数据库中SXSJ的表空间SXS文件在创建的时候由于达到最大块空间,增加了一个SXSJ1的数据文件,但是增加时直接给的文件大小是30G,过于占用空间,要修改为10G,但是在数据库中执行修改语句报一下错误:
Failed to commit: ORA-03297: 文件包含在请求的 RESIZE 值以外使用的数据
方法/步骤
1. 查询oracle本次修改的数据文件及其编号。
SQL语句如下:select file#,name from v$datafile;
执行后可以看到本次要修改的SXSJ1的文件对应的编号为:17
2. 查找该数据文件的最大块号。语句如下:
select max(block_id) from dba_extents where file_id=17;
查询到的最大块为:2205952
3. 显示SXSJ表空间每个数据块的大小。
语句如下: select tablespace_name,blocK_size,status,contents from dba_tablespaces where tablespace_name='SXSJ'数据库中得到的结果为8192,就是8K。
4. 计算该数据块占用的物理空间
语句如下:select 2205952*8/1024 from dual;
执行结果为: 17234,就是16个G左右
PS这里的2205952就是步骤②中的结果
5. 然后我们知道目前用了16G多,我们就可以把数据文件大小Resize到16G多一点 ,就到20G吧。
数据文件修改文件大小语句如下:ALTER DATABASE DATAFILE 'D:\app\Administrator\oradata\LZBDCSVR\SXSJ1' RESIZE 20G;
执行后命令成功执行
注意事项
· 说明:之所以执行失败是因为当初我们执行修改数据文件为10G,但是实际数据已经占用了16G多了,不能修改为10G,只能比实际值大些。
猜你喜欢
- 2025-07-10 整理汇总数据-执行失败:ORA-01438: 值大于为此列指定的允许精度
- 2025-07-10 oracle列转行以及C#执行语句时报错问题
- 2024-10-17 ORA-12514 TNS 监听程序当前无法识别连接描述符中请求服务
- 2024-10-17 mybatis中oracle模糊查询like concat报错
- 2024-10-17 如何高效进行Oracle巡检?顺序方法缺一不可
- 2024-10-17 详解4个方法--解决Oracle快照过旧问题
- 2024-10-17 Kettle 连接Oracle rac报ORA-12505错误解决方法
- 2024-10-17 centos7.4安装oracle11GR2报错解决办法
- 2024-10-17 centos安装oracle 11.2.0.1报错的处理方法
- 2024-10-17 详解Oracle数据库如何有效处理失效对象
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端路由 (61)
- 前端数组 (73)
- 前端js面试题 (50)
- 前端定时器 (59)
- Oracle RAC (76)
- oracle恢复 (77)
- oracle 删除表 (52)
- oracle 用户名 (80)
- oracle 工具 (55)
- oracle 内存 (55)
- oracle 导出表 (62)
- oracle约束 (54)
- oracle 中文 (51)
- oracle链接 (54)
- oracle的函数 (58)
- oracle面试 (55)
- 前端调试 (52)
本文暂时没有评论,来添加一个吧(●'◡'●)