Oracle报错ORA-01653: 表xx无法通过 8192在表空间中扩展

向Oracle 19g数据库中批量插入数据,当插入近2亿条数据后,报出如下错误:

ORA-01653: 表xx无法通过 8192 (在表空间 xx_data 中) 扩展

查看表空间,发现表空间大小已达到32G,表空间无法进行自动扩展了。(初始空间为20G)


  1. 查看Oracle的 DB_BLOCK_SIZE

    sql 复制代码
    # sys 登陆 oracle
    SQL> select value from v$parameter where name ='db_block_size';
    VALUE
    ---------------------------------------------------------------
    8192

    本机数据库的数据块大小为8K,得出本机Oracle 单个表空间数据文件的最大值为:4194304 * 8/1024 = 32768M (32G);

    所以既使创建表空间时设置了 autoextend on maxsize unlimited,其最大空间也是不会超过32G。

    1. 在初始建库时,DB_BLOCK_SIZE要根据实际需要,设置为 4K、8K、16K、32K、64K等几种大小;
    2. ORACLE的物理文件最大只允许4194304(2^22)个数据块;
  2. 查看表空间

    bash 复制代码
    # 查看表空间
    select * from   dba_tablespaces;
     
    # 查看表空间是否自动增
    SELECT FILE_NAME,TABLESPACE_NAME,AUTOEXTENSIBLE FROM dba_data_files;
     
    # 表空间文件位置
    select tablespace_name,file_id,bytes/1024/1024,file_name from dba_data_files order by file_id;  

    列出所有表空间的使用情况:

    bash 复制代码
    SELECT a.tablespace_name "表空间名称", 
     
    total / (1024 * 1024) "表空间大小(M)", 
     
    free / (1024 * 1024) "表空间剩余大小(M)", 
     
    (total - free) / (1024 * 1024 ) "表空间使用大小(M)", 
     
    total / (1024 * 1024 * 1024) "表空间大小(G)", 
     
    free / (1024 * 1024 * 1024) "表空间剩余大小(G)", 
     
    (total - free) / (1024 * 1024 * 1024) "表空间使用大小(G)", 
     
    round((total - free) / total, 4) * 100 "使用率 %" 
     
    FROM (SELECT tablespace_name, SUM(bytes) free 
     
    FROM dba_free_space 
     
    GROUP BY tablespace_name) a, 
     
    (SELECT tablespace_name, SUM(bytes) total 
     
    FROM dba_data_files 
     
    GROUP BY tablespace_name) b 
     
    WHERE a.tablespace_name = b.tablespace_name ;

解决

  1. 查看表空间是否自动增长

    sql 复制代码
    SELECT FILE_NAME,TABLESPACE_NAME,AUTOEXTENSIBLE FROM dba_data_files;-- 查看表空间是否自动增长
  2. 如果报错的表空间没有开启自动增加 ,则开启

    sql 复制代码
    ALTER DATABASE DATAFILE '/ora11g/data/oradata/lfzldb/LFZL.DBF' AUTOEXTEND ON NEXT 1024M ;	-- 每次自动增长1024M
  3. 当自动增长表空间也无效的情况

    当表空间为最大值,100%没办法自增的时候,这时可以考虑新增一个数据文件

    sql 复制代码
     Alter tablespace 表空间名 add datafile '数据文件路径' size 数据文件大小M autoextend on next 每次自增长大小M Maxsize UNLIMITED 
     --例
     Alter tablespace LFZL add datafile '/ora11g/data/oradata/lfzldb/LFZL2.DBF' size 10240M autoextend on next 1024M Maxsize UNLIMITED

    添加成功后,查看情况

相关推荐
@LetsTGBot搜索引擎机器人41 分钟前
2025 Telegram 最新免费社工库机器人(LetsTG可[特殊字符])搭建指南(含 Python 脚本)
数据库·搜索引擎·机器人·开源·全文检索·facebook·twitter
计算机毕设VX:Fegn08951 小时前
计算机毕业设计|基于springboot + vue动物园管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
冉冰学姐1 小时前
SSM校园排球联赛管理系统y513u(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架应用·开题报告、
Tony Bai2 小时前
【分布式系统】03 复制(上):“权威中心”的秩序 —— 主从架构、一致性与权衡
大数据·数据库·分布式·架构
wb043072013 小时前
SQL工坊不只是一个ORM框架
数据库·sql
至善迎风3 小时前
Redis完全指南:从诞生到实战
数据库·redis·缓存
QQ_4376643145 小时前
Redis协议与异步方式
数据库·redis·bootstrap
纪莫5 小时前
技术面:MySQL篇(InnoDB事务执行过程、事务隔离级别、事务并发异常)
数据库·java面试⑧股
Nerd Nirvana5 小时前
数据库模型全景:从原理到实践的系统性指南
数据库·oracle·电力行业
SelectDB5 小时前
从 Greenplum 到 Doris:集群缩减 2/3、年省数百万,度小满构建超大规模数据分析平台经验
数据库·数据分析·apache