标签云
asm恢复 bbed bootstrap$ dul In Memory kcbzib_kcrsds_1 kccpb_sanity_check_2 MySQL恢复 ORA-00312 ORA-00607 ORA-00704 ORA-00742 ORA-01110 ORA-01555 ORA-01578 ORA-01595 ORA-08103 ORA-600 2131 ORA-600 2662 ORA-600 3020 ORA-600 4000 ORA-600 4137 ORA-600 4193 ORA-600 4194 ORA-600 16703 ORA-600 kcbzib_kcrsds_1 ORA-600 KCLCHKBLK_4 ORA-15042 ORA-15196 ORACLE 12C oracle dul ORACLE PATCH Oracle Recovery Tools oracle加密恢复 oracle勒索 oracle勒索恢复 oracle异常恢复 Oracle 恢复 ORACLE恢复 ORACLE数据库恢复 oracle 比特币 OSD-04016 YOUR FILES ARE ENCRYPTED 勒索恢复 比特币加密文章分类
- Others (2)
- 中间件 (2)
- WebLogic (2)
- 操作系统 (103)
- 数据库 (1,753)
- DB2 (22)
- MySQL (76)
- Oracle (1,596)
- Data Guard (52)
- EXADATA (8)
- GoldenGate (24)
- ORA-xxxxx (162)
- ORACLE 12C (72)
- ORACLE 18C (6)
- ORACLE 19C (15)
- ORACLE 21C (3)
- Oracle 23ai (8)
- Oracle ASM (68)
- Oracle Bug (8)
- Oracle RAC (54)
- Oracle 安全 (6)
- Oracle 开发 (28)
- Oracle 监听 (28)
- Oracle备份恢复 (586)
- Oracle安装升级 (96)
- Oracle性能优化 (62)
- 专题索引 (5)
- 勒索恢复 (84)
- PostgreSQL (30)
- pdu工具 (6)
- PostgreSQL恢复 (9)
- SQL Server (31)
- SQL Server恢复 (12)
- TimesTen (7)
- 达梦数据库 (3)
- 达梦恢复 (1)
- 生活娱乐 (2)
- 至理名言 (11)
- 虚拟化 (2)
- VMware (2)
- 软件开发 (38)
- Asp.Net (9)
- JavaScript (12)
- PHP (2)
- 小工具 (21)
-
最近发表
- 达梦数据库dm.ctl文件异常恢复
- Oracle Recovery Tools修复ORA-00742、ORA-600 ktbair2: illegal inheritance故障
- 可能是 tempdb 空间用尽或某个系统表不一致故障处理
- 11.2.0.4库中遇到ORA-600 kcratr_nab_less_than_odr报错
- [MY-013183] [InnoDB] Assertion failure故障处理
- Oracle 19c 202504补丁(RUs+OJVM)-19.27
- Oracle Recovery Tools修复ORA-600 6101/kdxlin:psno out of range故障
- pdu完美支持金仓数据库恢复(KingbaseES)
- 虚拟机故障引起ORA-00310 ORA-00334故障处理
- pg创建gbk字符集库
- PostgreSQL运行日志管理
- ora-600 kdsgrp1 错误描述
- GAM、SGAM 或 PFS 页上存在页错误处理
- ORA-600 krhpfh_03-1208
- VMware勒索加密恢复(vmdk勒索恢复)
- ORA-39773: parse of metadata stream failed故障处理
- sql数据库备份失败—失败: 23(数据错误(循环冗余检查)
- vmdk文件被加密恢复(虚拟机文件加密)
- 差点被误操作的ORA-600 kcratr_nab_less_than_odr故障
- win平台19c 打patch遭遇2个小问题汇总
标签归档:varchar2 32k
ORACLE 12C varchar2支持32k长度字符串
在Oracle的以前版本中如果要存储超过4000byte的字符串需要使用clob字段,而lob本身操作就麻烦,而且效率不高。从12C开始Oracle提供了 VARCHAR2, NVARCHAR2, and RAW支持32k长度在字符串,大大提高了Oracle程序在处理4000到32k的字符串的处理效率.
数据库版本
SQL> select * from v$version; BANNER CON_ID -------------------------------------------------------------------------------- ---------- Oracle Database 12c Enterprise Edition Release 12.1.0.0.2 - 64bit 0 PL/SQL Release 12.1.0.0.2 0 CORE 12.1.0.0.2 0 TNS for Linux: Version 12.1.0.0.2 0 NLSRTL Version 12.1.0.0.2 0
max_sql_string_size参数
SQL> show parameter max_sql_string_size; NAME TYPE VALUE ------------------------------------ ----------- ------------------------------ max_sql_string_size string LEGACY max_sql_string_size:controls maximum size of VARCHAR2, NVARCHAR2, and RAW types in SQL max_sql_string_size, must be from among EXTENDED, LEGACY
创建测试表
SQL> create table t_xifenfei(id number,name varchar2(4001)); create table t_xifenfei(id number,name varchar2(4001)) * ERROR at line 1: ORA-00910: specified length too long for its datatype SQL> create table t_xifenfei(id number,name varchar2(4000)); Table created. SQL> insert into t_xifenfei values(1,rpad('www.xifenfei.com',4000,0)); 1 row created. SQL> insert into t_xifenfei values(2,lpad('www.xifenfei.com',4009,0)); 1 row created. SQL> commit; Commit complete. SQL> select id,length(name) from t_xifenfei; ID LENGTH(NAME) ---------- ------------ 1 4000 2 4000 SQL> select id,substr(name,-10,10) from t_xifenfei; ID SUBSTR(NAME,-10,10) ---------- ---------------------------------------- 1 0000000000 2 fenfei.com SQL> select id,substr(name,3990) from t_xifenfei; ID SUBSTR(NAME,3990) ---------- -------------------------------------------- 1 00000000000 2 ifenfei.com
测试说明几点:
1.默认情况下varchar2长度不能超过4000
2.插入varchar2超过4000的字段(列长度为4000),自动被截断
修改max_sql_string_size参数
SQL> alter system set max_sql_string_size='EXTENDED'; alter system set max_sql_string_size='EXTENDED' * ERROR at line 1: ORA-02097: parameter cannot be modified because specified value is invalid ORA-02096: specified initialization parameter is not modifiable with this option SQL> alter system set max_sql_string_size='EXTENDED' scope=spfile; System altered.
执行utl32k.sql脚本
SQL> shutdown immediate; Database closed. Database dismounted. ORACLE instance shut down. SQL> startup upgrade; ORACLE instance started. Total System Global Area 313159680 bytes Fixed Size 2259912 bytes Variable Size 243270712 bytes Database Buffers 62914560 bytes Redo Buffers 4714496 bytes Database mounted. Database opened. SQL> @?/rdbms/admin/utl32k.sql --包含编译无效对象 QL> shutdown immediate Database closed. Database dismounted. ORACLE instance shut down. SQL> startup ORACLE instance started. Total System Global Area 313159680 bytes Fixed Size 2259912 bytes Variable Size 251659320 bytes Database Buffers 54525952 bytes Redo Buffers 4714496 bytes Database mounted. Database opened. SQL> show parameter max_sql_string_size; NAME TYPE VALUE ------------------------------------ ----------- ---------------- max_sql_string_size string EXTENDED
测试varchar2(32767)
SQL> conn xff/xifenfei Connected. SQL> create table t_xifenfei_1(id number,name varchar2(32768)); create table t_xifenfei_1(id number,name varchar2(32768)) * ERROR at line 1: ORA-00910: specified length too long for its datatype SQL> create table t_xifenfei_extend(id number,name varchar2(32767)); Table created. SQL> insert into t_xifenfei_extend values(3,lpad('www.xifenfei.com',32767,0)); 1 row created. SQL> commit; Commit complete. SQL> select id,substr(name,-10,10) from t_xifenfei_extend; ID SUBSTR(NAME,-10,10) ---------- ---------------------------------------- 3 fenfei.com SQL> select id,substr(name,32760) from t_xifenfei_extend; ID SUBSTR(NAME,32760) ---------- -------------------------------- 3 nfei.com SQL> select id,length(name) from t_xifenfei_extend; ID LENGTH(NAME) ---------- ------------ 3 32767
Oracle 12C支持字符串32K处理过程
1.修改max_sql_string_size=’EXTENDED’
2.重启数据库至upgrade状态
3.执行@?/rdbms/admin/utl32k.sql
4.重启数据库至正常open状态