ADO.NET 3.5 Cookbook, 2nd Edition (O'Relly出版社)
Chapter 10 Optimizing .NET Data Access 的 讀書心得筆記
ADO.NET 3.5 Cookbook, 2nd Edition
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
透過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)
int tempIndex = dr.GetOrdinal("資料表的 欄位名稱");
dr[tempIndex]
提醒您 .GetOrdibal()方法傳回值是「 int 整數」。相關文章如下
http://stackoverflow.com/questions/1079366/why-use-the-getordinal-method-of-the-sqldatareader
http://www.c-sharpcorner.com/blogs/datareader-getordinal-performance-improvement1
透過 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也很棒,但後續就沒有推陳出新了
相關文章:
節錄自「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
我將思想傳授他人, 他人之所得,亦無損於我之所有;
猶如一人以我的燭火點燭,光亮與他同在,我卻不因此身處黑暗。----Thomas Jefferson
線上課程教學,遠距教學 (Web Form 約 51hr) https://dotblogs.com.tw/mis2000lab/2016/02/01/aspnet_online_learning_distance_education_VS2015
線上課程教學,遠距教學 (ASP.NET MVC 約 140hr) https://dotblogs.com.tw/mis2000lab/2018/08/14/ASPnet_MVC_Online_Learning_MIS2000Lab
寫信給我,不要私訊 -- mis2000lab (at) yahoo.com.tw 或 school (at) mis2000lab.net
(1) 第一天 ASP.NET MVC5 完整影片(5.5小時 / .NET 4.x版)免費試聽。影片 https://youtu.be/9spaHik87-A
(2) 第一天 ASP.NET Core MVC 完整影片(3小時 / .NET Core 6.0~8.0)免費試聽。影片 https://youtu.be/TSmwpT-Bx4I
[學員感言] mis2000lab課程評價 - ASP.NET MVC , WebForm 。 https://mis2000lab.medium.com/%E5%AD%B8%E5%93%A1%E6%84%9F%E8%A8%80-mis2000lab%E8%AA%B2%E7%A8%8B%E8%A9%95%E5%83%B9-asp-net-mvc-webform-77903ce9680b
ASP.NET遠距教學、線上課程(Web Form + MVC)。 第一天課程, "完整" 試聽。
......... facebook社團 https://www.facebook.com/mis2000lab ......................
......... YouTube (ASP.NET) 線上教學影片 https://www.youtube.com/channel/UC6IPPf6tvsNG8zX3u1LddvA/
Blog文章 "附的範例" 無法下載,請看 https://dotblogs.com.tw/mis2000lab/2016/03/14/2008_2015_mis2000lab_sample_download
請看我們的「售後服務」範圍(嚴格認定)。
......................................................................................................................................................
ASP.NET MVC => .NET Core MVC 線上教學 ...... 第一天課程 完整內容 "免費"讓您評估 / 試聽
[遠距教學、教學影片] ASP.NET (Web Form) 課程 上線了!MIS2000Lab.主講 事先錄好的影片,並非上課側錄! 觀看時,有如「一對一」面對面講課。