in

Darkthread

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

Browse by Tags

  • 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
  • 關於 Decimal 小數尾數零

    C#的實數型別有三種:float、double、decimal。其中 float、double 為浮點數,本站的老讀者們一定知道-「 算錢用浮點,遲早被人扁 」的道理,因此只要涉及金額計算,我一律改用 decimal 型別。前幾天,踩到 decimal 小數尾數零地雷一枚。 以下程式為例,大家猜猜結果為何? class Program { static void Main( string [] args) { float flt = 1.2300F; Console.WriteLine(flt); double dbl = 1.2300D; Console.WriteLine(dbl); decimal...
    公佈在 黑暗執行緒 (Weblog)Jeffrey 發表於 12-11-2016
  • C# Interpolated Strings 字串插值

    TypeScript 有個好東西, Template String ,輸出內嵌動態資料 HTML 時非常好用,例如: var userName: string = "Jeffrey" ; var iconUrl: string = "/imgs/runner.gif" ; var html = ` <div> Hello, ${userName}! <img src= "${iconUrl}" /> </div>`; alert(html); 場景移到 C#,字串內含換行符號靠 @"…."...
    公佈在 黑暗執行緒 (Weblog)Jeffrey 發表於 11-21-2016
第1頁,共25頁 (241個項目) 1 2 3 4 5 下一頁 > ... 最後一頁 »
Powered by Community Server (Non-Commercial Edition), by Telligent Systems