2016年3月17日 星期四

[讀書心得] .NET 資料存取最佳化的一些方法 (ADO.NET)

[讀書心得] .NET 資料存取最佳化的一些方法 (ADO.NET)
https://dotblogs.com.tw/mis2000lab/2016/03/17/adonet_35_cookbook_notebook



ADO.NET 3.5 Cookbook, 2nd Edition
By Bill Hamilton
http://shop.oreilly.com/product/9780596101404.do
這本書我似乎沒買到簡體中文翻譯本,但這兩天不小心看到原文版
幫自己整理一些讀書心得

以下重點源自 第十章 (原出版社 O'Relly 可以下載第十章範例來對照、參考)

Chapter 10   Optimizing .NET Data Access

=============================================================

同一連線內,如何執行多個命令(Command) ---- MARS (Multiple Active Result Sets,需搭配SQL 2005起的新版本)
      已分享的文章  https://dotblogs.com.tw/mis2000lab/2011/01/14/ado_net_book_sample_2_20010114

非同步的資料存取 ---- 書本裡面用的是老方法,.NET 4.5 (VS 2012)起有新的 Async與await,簡單好用。
    已經分享的文章  https://dotblogs.com.tw/mis2000lab/tags/1?qq=async
 

YouTube教學影片 -- https://youtu.be/8vcrjhaF1zE

IFrame

透過ASP.NET Cache (C#語法 Cache["變數"])將常用的數據 "快取"起來 ---- https://msdn.microsoft.com/zh-tw/library/ms178597(v=vs.100).aspx

改善 "分頁"的效率 ---- 這部分我倒是分享了不少範例,請看:https://dotblogs.com.tw/mis2000lab/tags/1?qq=%E5%88%86%E9%A0%81
  • 以下兩個範例都有提供 Youtube教學影片
              SQL 2005的 Row_Number -- https://dotblogs.com.tw/mis2000lab/archive/2010/11/30/datareader_paging_row_number.aspx
              SQL 2012的 Offset...Fetch -- https://dotblogs.com.tw/mis2000lab/archive/2014/07/17/page_sql2012_fetch_offset_20140717.aspx

改善 DataReader資料讀取的效率 ---- 請看 WizardWu網友的文章 http://www.cnblogs.com/WizardWu/archive/2010/02/16/1668769.html

使用DataReader的 .GetOrdinal()方法 -- https://msdn.microsoft.com/zh-tw/library/system.data.sqlclient.sqldatareader.getordinal(v=vs.110).aspx
      提醒您 -- 因為序數式查詢比具名查詢更有效率,因此在迴圈 (Loop) 中呼叫 .GetOrdinal()方法 會降低執行效能。
      藉由呼叫 .GetOrdinal()方法 一次並指派結果到在迴圈中使用的整數變數就可以節省時間。(源自 微軟MSDN)

透過 DataSet的 EnforceConstraints屬性,加速 .Fill()的效率
      https://msdn.microsoft.com/zh-tw/library/system.data.dataset.enforceconstraints(v=vs.110).aspx
     在嘗試任何更新作業時,是否遵循條件約束 (Constraint) 規則。(源自 微軟MSDN)

單一欄位寫入、讀取大量資料,請愛用SQL Server新的資料型態
      舊版的ntext, text與 image ,請改為SQL 2005起的nvarchar(max), varchar(max)與 varbinary(max)

=============================================================
後續有一些是連結 Oracle DB的建議,因為我都是搭配MS SQL Server,所以就沒看下去了。

O'Relly出版的書籍,有幾本名為 CookBook
這些名為「食譜」的書籍,簡單易懂。
以本書為例,他每一節就是一個問題,然後提供立即的解法&改善步驟。
是值得推薦的好書!

他們出版過一本 ASP.NET MVC 4的書(我買簡體中文翻譯本),至今我仍覺得是經典!http://shop.oreilly.com/product/0636920024040.do

不過,他們的書本未必每一版都有出書,如同本文介紹的 ADO.NET 3.5、MVC 4,後續版本就斷了......

ASP.NET 2.0 CookBook也很棒,但後續就沒有推陳出新了
Developing Real-World Web Applications with ASP.NET MVC    125 Solutions in C# and Visual Basic for Web Developers


相關文章:
[讀書心得]讓你的 ASP.NET程式(Web Form)效能更快
https://dotblogs.com.tw/mis2000lab/2011/01/20/asp_net_performance_20110120

    節錄自「Programming ASP.NET 3.5 , 4th Edition」一書(O'Reilly出版)

[好書推薦]ASP.NET全能速查寶典 / Programming ASP.NET 3.5中文版
https://dotblogs.com.tw/mis2000lab/2010/08/23/17366




2016年3月14日 星期一

.NET 4.5 非同步程式,從一張圖知道原來如此 (async & await)


.NET 4.5 非同步程式,從一張圖知道原來如此 (async & await)

https://dotblogs.com.tw/mis2000lab/2016/03/10/net45_easy_async_concept

在微軟MSDN網站上看到的範例,修正以後,從「執行結果」立刻看懂非同步程式
老美的俗諺:一圖解千言。有道理!  (本文搭配 YouTube教學影片)

這個範例源自微軟MSDN網站,https://msdn.microsoft.com/zh-tw/library/hh524395.aspx
但如同很多初學者看不懂原廠文件一樣,我也看不懂。
因為MSDN文件通常沒有圖片,連程式的執行結果都是用文字描述....... Orz

文字已經看不懂了,又沒圖片,就更難體會。
所以我改良(簡化)以後,直接用「執行成果」的圖片來解說,希望效果好一些。

先不要看程式,也不要去懂裡面的關鍵字 -- async 或await
我們拿起程式把玩一下,從執行結果瞭解「(傳統的)同步」&「非同步」有什麼不同?

YouTube教學影片 -- https://youtu.be/8vcrjhaF1zE



下圖的第一列程式碼,執行時間稍久,故意要他 Delay兩秒鐘才能完成。
採用「非同步」的作法,您可以看見:
      雖然做不完,但下一列(不用等待)可以緊跟著執行,所以畫面上出現執行時間,現在是「10秒」       
      等到程式全數跑完之後,最後出現的結果,是「12秒」
如果是傳統的「同步」作法,
    第一列程式碼卡住了,後面的只好乖乖等待囉。
    因為大家都在排隊,前面沒做完,後面繼續等。

這個範例用 Windows Form可以看出 Web Form網頁看不到的成果,
如果您連續、快速按下三次按鈕,會有什麼成果?
為什麼相同的作法,Web Form網頁無法呈現上圖效果?
(這就是 "網頁" 跟 "Windows程式"的差異囉  :-)  )

** 檔案下載 **   https://onedrive.live.com/?id=6F7F668080F24B20%21678&cid=6F7F668080F24B20
(請找檔名:WindowsFormsApplication1_AsyncEasy.rar)

很多東西,只要您用「範例」解說,先 Demo給人家看看成果
往往能吸引大家興趣

「哇!這個結果有趣,我想學  ^_^  原來如此,看到成果就懂了!」.....這是人之常情。

我的書本&課程,不會放「投影片」講理論
一定 "先" 執行範例給您看,您覺得有趣、有用、有瞭解,才繼續講下去

每一個觀念,我都有對應的範例,讓您親自操作!親自看見差異!

 

[遠距教學、教學影片] ASP.NET (Web Form) 課程 上線了!微軟MVP --MIS2000Lab.主講

事先錄製好的影片,並非上課時側錄!   觀看影片時,有如我「一對一」跟您面對面講課


相關文章:

[轉貼] 非同步(Async)讀取、寫入BLOB檔案

[.NET 4.5] ADO.NET / ASP.NET 使用 Async 和 Await 非同步 存取資料庫

[.NET 4.5] ASP.NET 使用 Async 和 Await (非同步) 同時發出多個 Web要求, 存取多個網頁


 
 
我將思想傳授他人, 他人之所得,亦無損於我之所有;
猶如一人以我的燭火點燭,光亮與他同在,我卻不因此身處黑暗。----Thomas Jefferson
......... 寫信給我,mis2000lab (at) yahoo.com.台灣 .....................................................................................
................   facebook社團   https://www.facebook.com/mis2000lab   ............................
................   Google+   https://plus.google.com/100202398389206570368/posts ..............
................  YouTube (ASP.NET) 線上教學影片  http://goo.gl/rGLocQ
(1). 我是初學者、要從頭學起、學習 [各種]控制項,瞭解ASP.NET生命週期與變革,請上這一班:        
ASP.NET 遠距教學,免出門,在家上課   上課時,老師 親自 線上講解!並非事先錄影!

[遠距教學、教學影片] ASP.NET (Web Form) 課程 上線了!微軟MVP --MIS2000Lab.主講

事先錄製好的影片,並非上課時側錄!   觀看影片時,有如我「一對一」跟您面對面講課