看板 Visual_Basic 關於我們 聯絡資訊
各位好 我的作業環境是VS2010 Ultimate + Framework 4.0 這支程式的目的是要將Access檔案中一個名為SalesCalc的Query所得到的結果 輸出到Excel中新增的名為output的工作表 以下是程式內容: Dim dbConn as New OledbConnection ("Provider=Microsoft.Jet.OLEDB.4.0; Data Source=xxx.mdb) Dim dbCmd as New OledbCommand ("select into [EXCEL 8.0;Database=xxx.xls].[output] from SalesCalc") dbCmd.ExecuteNonQuery() 直接在access中跑這段query會出現像下面的訊息 在將1個欄位的資料轉換為null時發生失敗 型態轉換錯誤發生的原因可能是在輸出資料表時有一到多個欄位的資料未符合資料型別 或欄位長度的屬性。例如在yes/no欄位中留空或是在型態為數字的欄位中輸入了一段文 字時就會造成這樣的錯誤。 您是否無論如何要忽略這些錯誤並繼續更新或附加此項查詢? 如果您要忽略這些錯誤請按下"是" (我的作業環境都是英文版的 逐句翻譯就大概這個樣子) 按下是之後依然可以做輸出的動作 但如果在vs的debug模式下執行會提示oledbException 例外訊息為division by zero (資料表中有些留空的資料是無法避免的, 所以一定會遇到這個問題) 所以請問是否有參數或方法可以讓它遇到像這個問題時可以無視轉換錯誤強制執行呢? 先謝謝指教囉 -- ※ 發信站: 批踢踢實業坊(ptt.cc) ◆ From: 220.128.60.124
DearKurt:建議用vs2010去產生相對應的Dataset 寫程式會比較簡單 07/14 17:34