解析ASP.NET MVC開發之查詢數據實例

目錄:

1)從明源動力到創新工場這一路走來

2)解析ASP.NET WebForm和Mvc開發的區別

-----------------------------------------------------------------------------------------------


對於.NET平臺上開發WebForm項目,程序員操作數據的方法主要是通過使用ADO.NET。而我們MVC操作數據庫呢? 與ADO.NET相比又有怎樣的優勢呢?

一,大家都在談的EF到底是什麼?

EF ,全稱Entity FramWork。就是微軟以ADO.NET爲基礎發展的所謂ORM(對象關係映射框架,或者說是數據持久化框架)。

簡單的來說就是根據實體對象操作數據表中數據的一種面向對象的操作框架,具體的底層也是調用ADO.NET。具體概念可以參考維基百科(點擊我轉到)。

下面我們就來演示怎麼使用EF來操作數據庫:

點擊這裏可以下載我創建數據庫的腳本文件,當然你也可以是使用自己的數據庫。

在數據庫關係圖中,表之間的關係是這樣的:

01221235-89c28a1925ad48f7a800c38ccdb77c1

1)怎麼創建實體對象模型文件

①創建基於ADO.NET的實體數據模型

我這裏在我的Models文件夾(可以在任意地方哦)上“右鍵”→“新建項”,然後點擊進入,在左側的模板中,選擇"數據",在右側就會看到“ADO.NET實體數據模型”的選項,如下圖:

01221956-b7692558afcf4e2db79930272481d76


②點擊創建,進入”實體數據模型嚮導“,這裏我們可以選擇,要怎樣創建實體數據模型

01222212-5a12548faad34243a48bbf4bf711e3b

注意:這裏你可以分別選擇一種模型,在下邊的框中看到這兩種模型的區別,這裏不多做解釋;

因爲我們是從已經有的數據庫創建實體模型,所以選擇第一種”從數據庫生成“


③點擊下一步,進入連接數據庫的嚮導,通過新建連接,可以連接到自己的SQL Server服務器,然後選擇我們所要連接的數據庫,同時會生成實體連接字符串,如下圖:

01222748-3c560288e1ff44369d8ed723295143c


④點擊下一步,選擇”實體框架版本“

01223109-d57d11630b18409299282167d49a53e


⑤下一步,選擇需要在模型中包含的數據庫對象,選擇”確定所生成對象的單複數形式“,其它保持默認,點擊完成。如下圖:

01223411-907cdee2cad04a499808d3d1737b341


這時會在我們的Models文件夾下邊生成一個edmx文件,同時EF框架的設計器幫我們生成了根據數據表關係生成的實體類的關係圖,如下圖:

01224021-d59943c70b0740d0a1b6ec5490a015e

注意:這裏是不是發現這個表跟我們在數據庫關係圖中看到的圖有點相似啊?是的,很相似,但是所表達的意義是不一樣的。數據庫視圖所展示的是數據表之間的關係,而這裏展示的EF幫我們根據數據表關係生成的實體類的關係;

2)生成的edmx文件到底是什麼?

edmx文件的代碼樹如下:

01224908-02859da6fe1d4b68bd1944b8b1356ed

①怎麼會是XML文件?

我們通過”右鍵“→”打開方式“→在”XML編輯器“中打開,可以發現這個edmx文件是一個標準的XML文件,其中主要有三大塊,描述的就是我們的實體對象和數據庫映射的關係。如下圖:

01225319-43ba368d88b54714987f3c58862924f

②.tt文件下怎麼生成了.cs文件?


  數據庫上下文類。

  在代碼樹中我們很容易的發現,在.tt文件下邊生成了.cs類文件。”OumindBlog.Context.cs“文件的代碼和作用如下:

//繼承自DbContext類,  
//數據上下文類,用於操作數據庫。負責維護實體狀態,以及根據實體對象包裝類的狀態屬性,生成不同的SQL語句執行
    public partial class OumindBlogEntities : DbContext
    {
        public OumindBlogEntities()
            : base("name=OumindBlogEntities")
        {
        }
                                                                                                                                   
        protected override void OnModelCreating(DbModelBuilder modelBuilder)
        {
            throw new UnintentionalCodeFirstException();
        }
                                                                                                                                   
        public DbSet<BlogArticle> BlogArticles { get; set; }
        public DbSet<BlogArticleCate> BlogArticleCates { get; set; }
        public DbSet<BlogUser> BlogUsers { get; set; }
        public DbSet<Enumeration> Enumerations { get; set; }
    }

  實體類。

  而另一個.tt文件生成的類是做什麼用呢?我們打開一個看代碼:


//EF按照實體模型生成的實體類
    public partial class BlogArticleCate
    {
        public BlogArticleCate()
        {
            this.BlogArticles = new HashSet<BlogArticle>();
        }
                                                                                                                              
        public int Id { get; set; }
        public int Author { get; set; }
        public string Name { get; set; }
        public string Remark { get; set; }
        public int Statu { get; set; }
        public bool IsDel { get; set; }
        public System.DateTime Addtime { get; set; }
                                                                                                                              
        //生成的外鍵屬性
        public virtual ICollection<BlogArticle> BlogArticles { get; set; }
        public virtual BlogUser BlogUser { get; set; }
    }


很容易的發現這些字段和我們數據庫中的字段是對應的,這就是EF按照實體模型生成的實體類,而且在還成了外鍵屬性。

---------------------------------------------------預備工作到此結束--------------------------------------------------

二,使用EF操作數據庫

在上面”OumindBlog.Context.cs“中生成繼承DbContext的OumindBlogEntities 的類,來維護實體狀態,並且操作數據庫,所以我們首先要創建該類的對象,並且操作數據的代碼如下:

//創建數據庫上下文類的對象
        OumindBlogEntities db = new OumindBlogEntities();
        #region 查詢文章列表+ActionResult Article()
        /// <summary>
        /// 查詢文章列表
        /// </summary>
        /// <returns></returns>
        public ActionResult Article()
        {
            //通過db對象獲取文章列表
            db.BlogArticles.Where(p => p.AIsDel == false);//使用Lamabda表達式來獲取爲被刪除的文章
                                                                                                                                  
            //使用Lamabda表達式來獲取數據
            //返回一個List<T>的對象來存儲文章列表
            List < Models.BlogArticle > list= db.BlogArticles.Where(p => p.AIsDel == false).ToList();
                                                                                                                                  
                                                                                                                                  
            //也可以使用Linq來獲取數據
            List<Models.BlogArticle> list1 = (from p in db.BlogArticles where p.AIsDel == false select p).ToList();
            //使用ViewData來傳遞list對象
            ViewData["DataList"] = list;
            return View();
        }
        #endregion

接着我們爲Article創建視圖,並且接收數據,
因爲我們需要使用BlogArticle對象來顯示數據,所以應該首先導入命名空間


<!------------首先導入命名空間------------->>
@using MvcApplication1.Models;

然後顯示數據的代碼是:

<!------------獲取數據並顯示html------------->>
    <div>
        <table id="tbList">
            <tr>
                <th>id</th>
                <th>標題</th>
                <th>分類</th>
                <th>狀態</th>
                <th>時間</th>
                <th>操作</th>
            </tr>
            <!--遍歷 Action方法 設置給 ViewData 的集合數據,生成HTML代碼-->
            @foreach (BlogArticle a in ViewData["DataList"] as List<BlogArticle>)
            {
                <tr>
                    <td>@a.AId</td>
                    <td>@a.ATitle</td>
                    <td>@a.BlogArticleCate.Name</td>
                    <td>@a.Enumeration.e_cname</td>
                    <td>@a.AAddtime</td>
                                                                                                                            
                </tr>
            }
        </table>
    </div>

運行的結果如下:

02004815-bcad339e2e9b4a3788e8c0ea3739b04


三,總結

1)EF框架根據我們的數據庫中數據模型生成實體數據模型;

2)實體數據模型爲一個edmx文件,且該文件爲一個標準的XML文件,主要描述實體對象和數據庫映射關係;

3).tt文件爲我們生成了數據庫上下文類(用於操作數據庫)和實體類(表示實體對象和外鍵屬性關係);

4)實體對象可以使用Lamabda表達式或者Linq來查詢需要的數據,並且使用一個List對象來存儲數據;

5)易於理解代碼,在實際的操作中不需要像ADO.net一樣創造大量的數據庫訪問層;



如果您覺得不錯,點擊右角贊一下吧!您的支持,是我寫作的動力!

畢業實習交流羣:221376964。你也可以關注我的新浪微博進行交流。

1.png


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章