Oracle nvarchar和varchar相互转换、联合查询

来源:清泛原创     2016-06-27 17:33:02    人气:     我有话说( 0 人参与)

场景:联合查询(union all)Oracle两张表,同一组字段的数据类型不一致,分别是nvarchar和varchar。这时联合查询报错如下:ora12704:字...

场景:联合查询(union all)Oracle两张表,同一组字段的数据类型不一致,分别是nvarchar和varchar。
这时联合查询报错如下:ora12704:字符集不匹配。

解决方法:需要对数据类型进行转换。
Specifying the USING CHAR_CS argument converts text into the database character set. The output datatype is VARCHAR2.
Specifying the USING NCHAR_CS argument converts text into the national character set. The output datatype isNVARCHAR2.

(A表字段c_xxx:varchar,B表c_xxx:nvarchar
select translate(c_xxx USING NCHAR_CS) from A
union all
select c_xxx from B

或者

select c_xxx from A
union all
select translate(c_xxx USING CHAR_CS) from B

注意:translate函数括号中没有逗号。
1、varchar
              可变长度的  非Unicode  数据,最长为8,000个字符。   
2、nvarchar
              可变长度的   Unicode    数据,最长为4,000个字符。

Oracle nvarchar varchar 相互转换 联合查询

注:本文为本站或本站会员原创优质内容,版权属于原作者及清泛网所有,
欢迎转载,转载时须注明版权并添加来源链接,谢谢合作! (编辑:admin)
分享到: