Oracle数据库 union连接时报 字符集不匹配 异常

比如这段SQL:

select r1.USERCODE, r1.ROLEID, r1.APQPID, '' SUPPLIERCODE
from SQM_APQP_MEMBER_ROLE r1
where r1.APQPID = 4393
union
select r1.USERCODE, r1.ROLEID, r1.APQPID, s.SUPPLIERCODE
from SQM_APQP_SUPPLIER_MEMBER r1
left join SQM_APQP_SUPPLIER s on s.USERCODE = r1.USERCODE
where r1.APQPID = 4393

我在测试库完全能执行,发布生产后就不能执行,报字符集不匹配的异常,当时吓尿了。Union前后两个子查询都能单独执行,一旦连接就报错。
首先测试和生产的数据库字符集都是UTF8,不是这个问题,然后比较字段类型时发现不同:s.SUPPLIERCODE 在测试的类型是varchar2,而生产是nvarchar2
然后就找到了问题,字段类型不一致时不能进行union连接,我用’’做了一个默认值,数据库默认为varchar2,所以生产报错。。。这里涉及一个点,varchar2可以兼容升级成nvarchar2,但不能向下兼容,所以当时就只能重新添加新字段(varchar2),把值复制过去,删除旧字段,重命名新字段。
从代码上解决的话,把空字符可以直接用null定义,但就不能发现问题所在。我觉得更好的解决的话,直接测试和生产脚本同步一下。另外,还有两个函数可以用:cast('xxx' as nvarchar2(50))to_char(s.SUPPLIERCODE),可以使字段类型保持一致。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值