全國最多中醫師線上諮詢網站-台灣中醫網
發文 回覆 瀏覽次數:2850
推到 Plurk!
推到 Facebook!

MS-SQL使用OPENROWSET讀DBF資料中文都是亂碼

答題得分者是:Mickey
bryan_yan
一般會員


發表:2
回覆:4
積分:1
註冊:2004-09-30

發送簡訊給我
#1 引用回覆 回覆 發表時間:2005-03-23 09:52:09 IP:211.23.xxx.xxx 未訂閱
我使用MS-SQL 2000讀取DBF中的資料,語法如下: SELECT * FROM OPENROWSET(’MICROSOFT.JET.OLEDB.4.0’,’dBase IV;HDR=NO;IMEX=2;DATABASE=C:\’,’SELECT * FROM [aaa.dbf]’) 分別在2台SQL SERVER執行相同語法,1台中文讀取正常,另1台中文會變成亂碼 檢查過DBCC USEROPTIONS與sp_configure的結果都相同 請問各位先進是否有方式可解決,謝謝
Mickey
版主


發表:77
回覆:1882
積分:1390
註冊:2002-12-11

發送簡訊給我
#2 引用回覆 回覆 發表時間:2005-03-26 00:30:56 IP:218.32.xxx.xxx 未訂閱
沒用過 MSSQL 這功能, 僅就我所知回應一下, 參考看看, 或許有幫助... DBASE 檔, 本身會紀錄 Language, 好像是...$1C 與 $1D 的位址 發表人 - Mickey 於 2005/03/26 00:32:47
bryan_yan
一般會員


發表:2
回覆:4
積分:1
註冊:2004-09-30

發送簡訊給我
#3 引用回覆 回覆 發表時間:2005-03-28 08:47:34 IP:211.23.xxx.xxx 未訂閱
非常感謝Mickey大大的回應 對於DBASE檔本身紀錄的Language我已檢查過是繁體中文沒錯 而且我已找到解決方式,但不知道算不算正統,我寫出我的做法 原本做法是: SELECT * FROM OPENROWSET(’MICROSOFT.JET.OLEDB.4.0’,’dBase IV;HDR=NO;IMEX=2;DATABASE=C:\’,’SELECT * FROM [aaa.dbf]’) 是以DBASE的DRIVER來開啟的, 但是我聽說用FOXPRO也可以開啟一般DBF的檔案 因此我改用FOXPRO的DRIVER來開啟 SELECT * FROM OPENROWSET(’MSDASQL’,’Driver=Microsoft Visual FoxPro Driver;SourceType=DBF;SourceDB=C:\’,’SELECT * FROM [aaa.dbf]’) 就成功獲得解決,若是有更好的做法的人還是可以告訴我
系統時間:2024-06-27 3:13:02
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!