更改oracle字符集

原来的字符集是GBK类型,或者是台湾的中文字符集,中文字符集很容易出现个别的汉子乱码。但是线上的oracle实例,因为与UTF8字符集又没有子集的关系,所以没有办法直接更改oracle实例字符集。所以只好先把原来的oracle数据导出来。新建一个数据库实例,然后先IMP导入了table的结构。加上参数rows=n

修改varchar2类型的栏位,把大小改为2倍,因为原本一个汉子是2字节,utf8一个汉子存储占用3字节。所以直接导入的话,会造出栏位太小,存储不下。这个可是使用lengthb函数来验证。

修改栏位大小的语法

 1 select 'alter table ' || table_name || ' modify ' || column_name ||
2 ' varchar2(' || case
3 when data_length > 2000 then
4 4000
5 else
6 (2 * data_length)
7 end || ');'
8 from user_tab_columns
9 where data_type = 'VARCHAR2'
10 and table_name in
11 (select table_name from all_tables where owner = 'BHEXPRESS')
12 order by table_name;

  用PL/SQL,把查询的结果拷贝到一个记事本上,然后大概以700条以下的语句来更改(过多会造成死机)。

全部更新完栏位的大小后,再一次IMP,把数据导进即可。

转载于:https://www.cnblogs.com/milo-xie/archive/2011/08/22/2149575.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值