通常而言,db2的输出显示乱码,都是字符编码的问题。
查看数据库的编码集:
[test@demo ~]$ db2 get db cfg for testdb|grep -i code
Database code page = 1208
Database code set = UTF-8
Database country/region code = 1
[test@demo ~]$ db2 get db cfg for testdb|grep -i terr
Database territory = US
数据库的编码集codeset在创建的时候就指定的,一旦创建后就无法修改,codepage是
db2内部对编码集数字表示,可理解为db2为字符编码集另起的一个代号,只在db2内部
意义,常用是1208对应UTF-8编码集,1386对应GBK编码集,819对应ISO8859-1
DB2支持的codepage官方文档如下:
https://www.ibm.com/support/knowledgecenter/SSEPGG_10.5.0/com.ibm.db2.luw.admin.nls.doc/doc/r0004565.html
UTF-8与其他编码集通常是兼容可以转换的,如1208与819,1208与1386是兼容可以互相转
换的,但是1386与819是不兼容的。
乱码显示与操作系统的编码集,db2codepage注册变量设置的编码集,还有create db指定
的数据库的编码集都有关系。
操作系统的编码:
[test&#