初探EntityFramework——来自数据库的EF设计器
本文通過簡單的示例,先初步了解下EF四種設計模式之一:來自數據庫的EF設計器。
來自數據庫的EF設計器,顧名思義,需要有新建的數據庫和表結構,才能生成EF設計器,?在本地新建數據庫KTStore,并且新建表Produtc,表結構及表中的數據如下圖所示:
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ??
?
新建新的控制臺應用程序:EFDemo,如下圖所示:
? ? ? ? ? ? ? ? ? ? ? ? ???
?
右鍵項目,選擇“添加”,然后是“新建項”,如下圖所示:
? ? ? ? ? ? ? ? ? ? ? ? ??
?
?
在對話框中選擇“ADO.NET”實體數據模型,如下圖所示:?
?
單擊“添加”后,在彈出的窗口中,選擇“來自數據庫的EF設計器”,如下圖所示:
? ? ? ? ? ? ? ? ? ? ? ? ? ??
?
點擊下一步后,點擊“新建連接”?:
? ? ? ? ? ? ? ? ? ? ? ? ? ? ??
?
點擊“更改” :
? ? ? ? ? ? ? ? ? ? ? ? ? ? ??
?
根據實際情況選擇要連接數據庫還是數據庫文件,我選的是數據庫:
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ???
?
填寫數據庫連接數據,如下圖所示:?
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ??
?
然后點擊“測試連接”,如下圖所示:
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ??
?
點擊“確定”后,顯示出如下對話框,可以看到自動生成了連接字符串:
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ??
?
然后根據實際情況,選擇是否顯示連接字符串中的敏感信息,如賬號密碼什么的,我這邊為了方便查看選擇顯示:
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ??
?
點擊“下一步”,選擇“實體框架6.x”,如下圖所示:
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ??
?
點擊“下一步”,在彈出的窗口中選擇需要加入的表,如下圖所示,選擇Product表,并點擊“完成”按鈕即可。
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ??
?
完成后,可以看到,解決方案中增加了一些文件和DLL,這些都是EF框架自動生成的,如下圖所示?:
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?
?
回到Program.cs界面增加如下代碼:
namespace EFDemo {class Program{static void Main(string[] args){KTStoreEntities db = new KTStoreEntities();Console.WriteLine("商品數據項數:{0}\n", db.Product.Count());IEnumerable<Product> rows = db.Product.Select(x => x);foreach (Product p in rows){int id = p.Id;string name = p.Name;int? price = p.Price;string category = p.Category;Console.Write("{3}\t 定價:{2}\t{0}\t{1}\n",id,name,price,category);}Console.Read();}} }運行程序,EF框架自動從數據庫獲取數據并顯示,結果如下圖所示:
?
?
?
總結
以上是生活随笔為你收集整理的初探EntityFramework——来自数据库的EF设计器的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: python面向对象编程之访问限制
- 下一篇: 明令禁止工作“996”,是对“生而为人”