in

Darkthread

黑暗執行緒
All Tags » .NET (RSS)

Browse by Tags

  • CSV 轉換利器-ServiceStack.Text

    做專案免不了遇到匯出或讀取 CSV 的需求,將物件轉成逗號分隔字串看似小菜一碟,用 C# 串字串也能搞定,但魔鬼在細節裡:字串值如包含逗號就要用雙引號包夾,遇到雙引號要置換成兩個雙引號,如果字串內容有換行符號更是讀取識別時的一大挑戰… 不管是匯出或解析 CSV 都得費不少力氣。最近發現一個處理 CSV 的強大元件-ServiceStack.Text 的 CsvSerializer! ServiceStack 是一套用於快速打造 SOA 服務的 Framework 工具組(可取代 WCF、WebAPI),強調輕巧、快速。 ServiceStack.Text 則是其中處理 JSON、CSV、JSV...
    公佈在 黑暗執行緒 (Weblog)Jeffrey 發表於 05-12-2017
  • 使用 WebClient FTP 上傳檔案發生 553 錯誤

    在 .NET 要 FTP 上傳檔案,最精簡有效的做法莫過於 使用 WebClient ,例如: using System; using System.IO; using System.Net; public class CSharpLab { public static void Test() { string userName = "ftpAccount" ; string password = "ftpPassword" ; string uploadUrl = "ftp://myFtpServerHost/someFolder/test.txt"...
    公佈在 黑暗執行緒 (Weblog)Jeffrey 發表於 05-02-2017
  • MS OracleClient 改用 ODP.NET 之數字型別差異

    System.Data.OracleClient 被微軟宣告為 過時不建議使用 ,是你知道我知道連獨眼龍都知道的事,硬要繼續用甚至會有 效能懲罰 。所以在維護舊專案時,看到還在用 System.Data.OracleClient 的程式,我都會順手換成 Managed ODP.NET 。(若為 .NET 3.5 平台則只能用 Unmanaged ODP.NET) 近日踩到小鐵釘一根。 如下圖,程式原本使用 System.Data.OracleClient,執行正常: 改 using Oracle.ManagedDataAccess.Client 換用 Managed ODP.NET,出現型別轉換錯誤...
    公佈在 黑暗執行緒 (Weblog)Jeffrey 發表於 04-20-2017
  • OracleParameter 型別不符導致 ORA-03111 通訊中斷錯誤

    記錄在 Oracle 遇到的古怪錯誤。 Oracle Server 版本 10.2.0.4 64bit,Client 端用 Managed ODP.NET 12.1.24160719(取自 NuGet),某段程式碼誤傳 Varchar2 OracleParameter 與 DATE 欄位進行比對,預期應出現型別不符錯誤,但得到錯誤訊息為 ORA-03111 在通訊通道上收到中斷訊號( Break received on communication channel ): 該資料表有其他 DATE 欄位,將 WHERE 條件換成其他 DATE 欄位,也會觸發 ORA-03111。 另一個資料表也有類似...
    公佈在 黑暗執行緒 (Weblog)Jeffrey 發表於 03-22-2017
  • 使用 Process Explorer 查看 .NET Callstack

    WinDbg 追查 CPU 飆高問題 一文發表後,在 FB 收到網友 Webber Han 回饋(在此感謝),提到射茶包利器 Process Explorer 也能像 WinDbg 一樣檢視 Callstack 中的 .NET 組件、函式資訊,查了一下,這是 2012 年 15.2 版就加入的功能,Lag 大了。 關鍵在於「Configure Symbols」有無設定妥當,Process Explorer 的 .NET Callstack 解析也是借助 WinDbg 完成,故機器要先裝妥 WinDbg,開啟 Process Explorer 選單 Options / Configure Symbols...
    公佈在 黑暗執行緒 (Weblog)Jeffrey 發表於 02-27-2017
  • 用 100 行 C# 打造 IP 所屬國家快速查詢功能

    講到由 IP 地址查詢所屬國家,解決方案有兩種:第一種是直接呼叫線上查詢 API(付費或免費),再不然就要下載 IP 區段資料庫自寫查詢程式。考量應用場合不一定有 Internet 連線能力,加上擔心線上 API 無法滿足 IIS Log 等超大量 IP 解析的效能要求,選擇取回資料檔自幹。(其實是因為這題目大小難易適中,十分適合練功,一時手癢難耐,就…) 爬文找到一些 IP 國別對應資料來源: Maxmind GeoIP2 https://www.maxmind.com/en/geoip2-country-database Maxmind 在 Stackoverflow 受到不少網友推薦。精準度高...
    公佈在 黑暗執行緒 (Weblog)Jeffrey 發表於 02-12-2017
  • 使用非同步處理提升資料庫更新速度

    來自同事的資料庫程式效能調校案例一則。 情境為一支同步來源及目的資料表的排程,先一次取回來源及目的資料表,逐一檢查資料是否已存在目的資料表,若不存在即執行Insert,若存在則執行 Update 更新欄位。因 Insert/Update 之前需進行特定轉換,故難以改寫為 Stored Procedure。排程有執行過慢問題,處理四萬筆資料耗時近 27 分鐘。 程式示意如下: foreach (var src in srcList) { try { var target = findExistingData(src); if (target == null ) { AddTargetToDB(src...
    公佈在 黑暗執行緒 (Weblog)Jeffrey 發表於 02-09-2017
  • 使用 FileChangeMonitor 實現檔案資料快取自動更新

    有個開發老鳥專屬的「成功經驗魔咒」:遇到難題,想出一套簡單有效解法,或許有些小缺點,但造成的麻煩在可忍受範圍,於是 日後再遇到同樣狀況,一律照方煎藥,數十年如一日。 但技術會革新、元件會改進,善用一些新特性,小缺點其實可以化為無形。可怕的地方在於:如果每次都能順利解決問題,就不會圖謀改進,直到有天發現洋人船堅砲利,才知自己已成滿清… 老鳥想一直寫程式又不想被時代淘汰,就得提高警覺。有個超簡單的實踐方法-對自己機車一點。當有人反應不方便時,別一句「就多一個動作會死嗎?」頂回去,改成問自己:「連這個動作都省不掉?嫩!」,對自己GY一點才能撐久一點。以下算是個實例: 專案有時會遇到上傳檔案更新資料的機制...
    公佈在 黑暗執行緒 (Weblog)Jeffrey 發表於 01-16-2017
  • 筆記-Scott Hanselman 的 2017 .NET 開發者須知

    Scott Hanselman 前兩天有篇文章- What .NET Developers ought to know to start in 2017 ,我的工作(甚至生活)跟 .NET 息息相關,重量級人物的觀點自然不容錯過,整理筆記如下: 前言 Scott 之前整理過類似的 .NET 須知,結果被大家拿來當作面試時折磨新人的刑具… 清單很長,但並不是每則都必須搞懂弄通,應視自己所需以及學習習慣取捨,有些知道名詞即可,有些應該深入了解。 https://dot.net 是 .NET 技術資源的新入口,首頁有個線上 C# 編譯器可以玩玩。 必備知識 新的 .NET 架構 ,分成 .NET Framework...
    公佈在 黑暗執行緒 (Weblog)Jeffrey 發表於 01-15-2017
  • ODP.NET 發行者原則檔經驗一則

    之前處理過一個 鳥問題 ,使用 ODP.NET 12.1 連線 Oracle Server 10.2.0.4 時無法參與分散式交易,傳回「Unable to enlist in a distributed transaction /無法列於分散式交易中」錯誤。依網路討論 Server 升級到 10.2.0.5 以上可解決,當時決定將資料庫移至另一台 Oracle Server 11.2 成功脫逃,安全下莊。 半年後鳥問題捲土重來,一樣是 ODP.NET 12.1 連 Oracle 10.2.0.4 無法分散式交易,但這回資料庫沒得搬也很難升級,只能乖乖面對。 確認其他機器曾有 ODP.NET 11...
    公佈在 黑暗執行緒 (Weblog)Jeffrey 發表於 01-05-2017
第1頁,共25頁 (243個項目) 1 2 3 4 5 下一頁 > ... 最後一頁 »
Powered by Community Server (Non-Commercial Edition), by Telligent Systems