Oracle 关于union的字符集不匹配问题

在使用union连接时,报字符集不匹配错误

后续查找发现是因为union两端连接的表A、表B中字段work数据类型不同,表A中work字段数据类型为NVARCHAR2(256),表B中work字段数据类型为VARCHAR2(256)且数据为空,故执行union连接SQL时报错

因正式环境表A中work字段数据类型为VARCHAR2(256),为了保持一致,故想将表A中的work字段数据类型修改为VARCHAR2(256)

alter table A modify work VARCHAR2(256);

当所修改的字段下内容不为空时无法修改:

解决办法:

alter table A rename column work to workNew;--修改原字段名work 为workNew
alter table A add work VARCHAR2(256);--增加一个和原字段名同名的字段work
update A set work=trim(workNew);--将原字段workNew数据更新到增加的字段work(trim()会同时删除字符串前后出现的空格)
alter table A drop column workNew;--更新完,删除原字段workNew

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值