更改oracle字符集
2011-08-22 15:23
357 查看
原来的字符集是GBK类型,或者是台湾的中文字符集,中文字符集很容易出现个别的汉子乱码。但是线上的oracle实例,因为与UTF8字符集又没有子集的关系,所以没有办法直接更改oracle实例字符集。所以只好先把原来的oracle数据导出来。新建一个数据库实例,然后先IMP导入了table的结构。加上参数rows=n
修改varchar2类型的栏位,把大小改为2倍,因为原本一个汉子是2字节,utf8一个汉子存储占用3字节。所以直接导入的话,会造出栏位太小,存储不下。这个可是使用lengthb函数来验证。
修改栏位大小的语法
用PL/SQL,把查询的结果拷贝到一个记事本上,然后大概以700条以下的语句来更改(过多会造成死机)。
全部更新完栏位的大小后,再一次IMP,把数据导进即可。
修改varchar2类型的栏位,把大小改为2倍,因为原本一个汉子是2字节,utf8一个汉子存储占用3字节。所以直接导入的话,会造出栏位太小,存储不下。这个可是使用lengthb函数来验证。
修改栏位大小的语法
select 'alter table ' || table_name || ' modify ' || column_name || ' varchar2(' || case when data_length > 2000 then 4000 else (2 * data_length) end || ');' from user_tab_columns where data_type = 'VARCHAR2' and table_name in (select table_name from all_tables where owner = 'BHEXPRESS') order by table_name;
用PL/SQL,把查询的结果拷贝到一个记事本上,然后大概以700条以下的语句来更改(过多会造成死机)。
全部更新完栏位的大小后,再一次IMP,把数据导进即可。
相关文章推荐
- 更改Oracle实例的字符集
- oracle9204更改字符集步骤方法
- oracle 11g更改字符集
- oracle安装成功后,更改字符集
- Oracle 更改字符集
- oracle 11g 更改字符集,9i导入11g 出现 ORACLE 错误 12899 处理
- 更改oracle字符集
- Oracle 9i 字符集的更改
- 更改Oracle字符集
- 从oracle 10g转到oracle 11g更改字符集
- Oracle 11G 更改字符集
- 如何更改oracle字符集
- ORACLE XE 11G 字符集更改为zhs16gbk
- oracle 更改字符集
- Oracle 11G 更改字符集
- oracle更改字符集
- 更改oracle字符集
- 如何更改Oracle字符集
- Linux下更改oracle客户端字符集和服务端字符集
- Oracle更改字符集