亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費(fèi)注冊(cè) 查看新帖 |

Chinaunix

  平臺(tái) 論壇 博客 文庫(kù)
最近訪問板塊 發(fā)新帖
查看: 9719 | 回復(fù): 1
打印 上一主題 下一主題

AS400轉(zhuǎn)碼問題解決方案 [復(fù)制鏈接]

論壇徽章:
0
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報(bào)告]
發(fā)表于 2013-11-12 14:32 |只看該作者 |倒序?yàn)g覽
數(shù)據(jù)文件如下:
TESTPF
AF CHAR 200 CCSID 37 ( 200A)
VALUE: '一堆簡(jiǎn)體中文加數(shù)字12345加字母abcde的值'

TESTPF2
AF CHAR 200 CCSID 935 (200O)

對(duì)TESTPF 在AS400上通過SQL,QRY讀寫均能正確識(shí)別為中文。
但通過TTO或者ODBC/JDBC下載時(shí),將會(huì)被識(shí)別為亂碼。

以往解決亂碼問題時(shí),往往是通過CHGPF命令,將TESTPF的AF字段修改為O型(CCSID 935)。或者創(chuàng)建一個(gè)TESTPF2,通過CPYF命令將TESTPF的內(nèi)容拷貝到TESTPF2,通過FMTOPT(*NOCHK)參數(shù)自動(dòng)轉(zhuǎn)碼來完成。當(dāng)然也可以在JDBC中通過反射機(jī)制修改字段的CCSID值來自動(dòng)轉(zhuǎn)碼。但以上方法都存在缺陷,要么需要對(duì)原始數(shù)據(jù)表進(jìn)行修改,要么需要額外的存儲(chǔ)空間,需要能創(chuàng)建新的PF或者修改PF的權(quán)限,要么只能定做轉(zhuǎn)碼方法(JDBC反射方法)。

現(xiàn)發(fā)現(xiàn)一個(gè)新的方法,直接通過SQL方式自動(dòng)轉(zhuǎn)碼。方法如下:

SELECT CAST(AF AS CHAR(200) CCSID 935) FROM(
   SELECT CAST(AF AS CHAR(200) CCSID 65535) FROM TESTPF
   ) AS TESTPF

通過以上方法,就能將CCSID為37的字段的通過SQL方法轉(zhuǎn)碼為935并正確輸出。

以上方法中如果去掉先將37轉(zhuǎn)為65535的操作(CAST(AF AS CHAR(200) CCSID 65535))的話,轉(zhuǎn)碼出來的結(jié)果將不正確,會(huì)出現(xiàn)部分中文字符轉(zhuǎn)碼成功,部分失敗的情況。

但如果通過先轉(zhuǎn)為65535方法后再轉(zhuǎn)為935,則能正確轉(zhuǎn)換。

CAST的詳細(xì)說明




詳情見SQL reference


論壇徽章:
0
2 [報(bào)告]
發(fā)表于 2013-11-27 17:21 |只看該作者
帥! 樓主是個(gè)做技術(shù)的人!
您需要登錄后才可以回帖 登錄 | 注冊(cè)

本版積分規(guī)則 發(fā)表回復(fù)

  

北京盛拓優(yōu)訊信息技術(shù)有限公司. 版權(quán)所有 京ICP備16024965號(hào)-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號(hào):11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報(bào)專區(qū)
中國(guó)互聯(lián)網(wǎng)協(xié)會(huì)會(huì)員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請(qǐng)注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP