在使用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