Oracle 数据库 varchar2 从 4000 扩展到 32k
- [0. 引言](#0. 引言)
- [1. 扩展 varchar2 支持长度](#1. 扩展 varchar2 支持长度)
- [2. 测试](#2. 测试)
0. 引言
今天来个项目需求,有1个字段的存储内容大概1万字。
当然其中1个方法是将这个字段的内容切分成几个字段,还有1个方法就是将 varchar2 默认支持 4000 的能力扩展到 32k。
接下来就试一试吧。
1. 扩展 varchar2 支持长度
使用 sysdaba 连接数据库,
sqlplus / as sysdba
查看 pdbs,
show pdbs;
关闭要扩展的 pdb,
ALTER PLUGGABLE DATABASE ORCLPDB1 CLOSE;
以 upgrade 模式 open,
ALTER PLUGGABLE DATABASE ORCLPDB1 OPEN UPGRADE;
将 session 切换到要扩展的 pdb,
ALTER SESSION SET CONTAINER=ORCLPDB1;
将 PDB 中的 MAX_STRING_SIZE 设置更改为 EXTENDED,
ALTER SYSTEM SET MAX_STRING_SIZE=EXTENDED;
在 PDB 中运行 rdbms/admin/utl32k.sql 脚本。您必须以 SYSDBA 身份连接才能运行 utl32k.sql 脚本,
@?/rdbms/admin/utl32k.sql
关闭要扩展的 pdb,
ALTER PLUGGABLE DATABASE ORCLPDB1 CLOSE;
以正常模式 open,
ALTER PLUGGABLE DATABASE ORCLPDB1 OPEN;
2. 测试
执行下面建表语句,如果能够正常执行,说明扩展成功,
CREATE TABLE large_text_table (
large_text_column VARCHAR2(20000)
);