VFP 愛用者社區 首頁 VFP 愛用者社區
本討論區為 Visual Foxpro 愛用者經驗交流的地方, 請多多利用"搜尋"的功能, 先查看看有無前例可循, 如果還有不懂的再發問. 部份主題有附加檔案, 須先註冊成為社區居民才可以下載.
 
 常見問題常見問題   搜尋搜尋   會員列表會員列表   會員群組會員群組   會員註冊會員註冊 
 個人資料個人資料   登入檢查您的私人訊息登入檢查您的私人訊息   登入登入

用ODBC抓取DBF ,但資料筆數卻不一致?

 
發表新主題   回覆主題    VFP 愛用者社區 首頁 -> VFP 討論區
上一篇主題 :: 下一篇主題  
發表人 內容
anlun.li



註冊時間: 2015-06-02
文章: 2


第 1 樓

發表發表於: 星期二 九月 15, 2015 4:39 pm    文章主題: 用ODBC抓取DBF ,但資料筆數卻不一致? 引言回覆

各位大大好:
目前因為客戶的資料要將DBF轉至SQL SERVER,所以我以c#用ODBC 的方式來抓取,抓取的過程很正常,但資料筆數卻多了好幾筆,不知道有人有發生過類似的情形嗎?
代碼:

           string connetionString2 = "Driver={Microsoft Visual FoxPro Driver};SourceType=DBC;SourceDB=C:\DBF\;Exclusive=No;NULL=NO;Collate=Machine;BACKGROUNDFETCH=NO;DELETED=NO;";
            OdbcConnection cnn2;
           
            cnn2 = new OdbcConnection(connetionString2);
            try
            {
                cnn2.Open();

            }
            catch (Exception ex)
            {
             

                //Console.WriteLine("無法連線DBF ! ");
            }
     
           
            OdbcCommand dbfcmd = new OdbcCommand("select * from 104VOUC ", cnn2);
            OdbcDataReader odbcreader = dbfcmd.ExecuteReader();

我抓到odbcreader的筆數是"2363",但我用PowerBuilder 去看104VOUC這個TABLE 的筆數卻是"2336",
我也試過用Excel以OLEDB去抓,抓到的筆數也是"2363",我比對兩者的資料,是有些key值有重覆,但後面欄位不一樣的資料。
因為google 了很久,但沒有找到類似的問題,不曉得有人知道問題在哪裡嗎?
回頂端
檢視會員個人資料 發送私人訊息
garfield
Site Admin


註冊時間: 2003-01-30
文章: 2160


第 2 樓

發表發表於: 星期三 九月 16, 2015 12:38 pm    文章主題: 引言回覆

將 DELETED=NO; 改成 ;DELETED=YES
應該就是你要的結果.

_________________
利用>>搜尋<<的功能會比問的還要快得到答案.
回頂端
檢視會員個人資料 發送私人訊息 發送電子郵件
anlun.li



註冊時間: 2015-06-02
文章: 2


第 3 樓

發表發表於: 星期四 九月 17, 2015 2:18 pm    文章主題: 引言回覆

garfield 寫到:
將 DELETED=NO; 改成 ;DELETED=YES
應該就是你要的結果.

謝謝大大的告知,改成DELETED=YES後,筆數只多了一筆,我會再試試其他的設定。
回頂端
檢視會員個人資料 發送私人訊息
從之前的文章開始顯示:   
發表新主題   回覆主題    VFP 愛用者社區 首頁 -> VFP 討論區 所有的時間均為 台北時間 (GMT + 8 小時)
1頁(共1頁)

 
前往:  
無法 在這個版面發表文章
無法 在這個版面回覆文章
無法 在這個版面編輯文章
無法 在這個版面刪除文章
無法 在這個版面進行投票
無法 在這個版面附加檔案
無法 在這個版面下載檔案


Powered by phpBB © 2001, 2005 phpBB Group
正體中文語系由 phpbb-tw 維護製作