ASP.NET MVC5+EF6+EasyUI 後臺管理系統(5)-EF增刪改查

系列目錄html

前言

爲了符合後面更新後的重構系統,文章於2016-11-1日重寫數據庫

回顧上一節的解決方案,咱們看出瞭解決方案中類庫的關係數組

這裏要說明一點MVC!=三層ide

他們大約是這樣的一種關係spa

代碼實現

上一節咱們在EF添加了一個實體,此次咱們來看看怎麼操做這個實體,下面咱們建立IDAL,DAL,IBLL,BLL的代碼:code

新建一個SysSampleController的控制器:不須要寫什麼代碼,系統自動生成Index方法:分別在各層添加下列代碼:htm

using System;
using System.Linq;
using Apps.IDAL;
using Apps.Models;
using System.Data;

namespace Apps.DAL
{
    public class SysSampleRepository : ISysSampleRepository, IDisposable
    {
        /// <summary>
    /// 獲取列表
    ///
</summary>
        /// <param name="db">數據庫上下文</param>
        /// <returns>數據列表</returns>
        public IQueryable<SysSample>GetList(DBContainer db)
        {
            IQueryable<SysSample>
                list = db.SysSample.AsQueryable();
            return list;
        }
        /// <summary>
            /// 建立一個實體
            ///
        </summary>
        /// <param name="db">數據庫上下文</param>
        /// <param name="entity">實體</param>
        public int Create(SysSample entity)
        {
            using (DBContainer db = new DBContainer())
            {
                db.Set<SysSample>().Add(entity);
                return db.SaveChanges();
            }
        }
        /// <summary>
            /// 刪除一個實體
            ///
        </summary>
        /// <param name="db">數據庫上下文</param>
        /// <param name="entity">主鍵ID</param>
        public int Delete(string id)
        {
            using (DBContainer db = new DBContainer())
            {
                SysSample entity = db.SysSample.SingleOrDefault(a => a.Id == id);
                db.Set<SysSample>().Remove(entity);
                return db.SaveChanges() > 0;
            }
        }

        /// <summary>
            /// 修改一個實體
            ///
        </summary>
        /// <param name="db">數據庫上下文</param>
        /// <param name="entity">實體</param>
        public int Edit(SysSample entity)
        {
            using (DBContainer db = new DBContainer())
            {
                db.Set<entity>().Attach(entity);
                db.Entry<SysSample>(entity).State = EntityState.Modified;
                return db.SaveChanges();
            }
        }
        /// <summary>
            /// 得到一個實體
            ///
        </summary>
        /// <param name="id">id</param>
        /// <returns>實體</returns>
        public SysSample GetById(string id)
        {
            using (DBContainer db = new DBContainer())
            {
                return db.SysSample.SingleOrDefault(a => a.Id == id);
            }
        }
        /// <summary>
            /// 判斷一個實體是否存在
            ///
        </summary>
        /// <param name="id">id</param>
        /// <returns>是否存在 true or false</returns>
        public bool IsExist(string id)
        {
            using (DBContainer db = new DBContainer())
            {
                SysSample entity = GetById(id);
                if (entity != null)
                    return true;
                return false;
            }
        }
        public void Dispose()
        {

        }
    }
}
DAL層-SysSampleRepository
using Apps.Models;
using System.Linq;
namespace Apps.IDAL
{
    public interface ISysSampleRepository
    {
        /// <summary>
        /// 獲取列表
        /// </summary>
        /// <param name="db">數據庫上下文</param>
        /// <returns>數據列表</returns>
        IQueryable<SysSample> GetList(DBContainer db);
        /// <summary>
        /// 建立一個實體
        /// </summary>
        /// <param name="entity">實體</param>
        int Create(SysSample entity);
        /// <summary>
        /// 刪除一個實體
        /// </summary>
        /// <param name="entity">主鍵ID</param>
        int Delete(string id);

        /// <summary>
        /// 修改一個實體
        /// </summary>
        /// <param name="entity">實體</param>
        int Edit(SysSample entity);
        /// <summary>
        /// 得到一個實體
        /// </summary>
        /// <param name="id">id</param>
        /// <returns>實體</returns>
        SysSample GetById(string id);
        /// <summary>
        /// 判斷一個實體是否存在
        /// </summary>
        bool IsExist(string id);
    }
}
IDAL層-ISysSampleRepository
using System.Collections.Generic;
using App.Common;
using App.Models.Sys;


namespace App.IBLL
{

    public interface ISysSampleBLL
    {
        /// <summary>
        /// 獲取列表
        /// </summary>
        /// <param name="pager">JQgrid分頁</param>
        /// <param name="queryStr">搜索條件</param>
        /// <returns>列表</returns>
        List<SysSampleModel> GetList(ref GridPager pager, string queryStr);
        /// <summary>
        /// 建立一個實體
        /// </summary>
        /// <param name="errors">持久的錯誤信息</param>
        /// <param name="model">模型</param>
        /// <returns>是否成功</returns>
        bool Create(ref ValidationErrors errors, SysSampleModel model);
        /// <summary>
        /// 刪除一個實體
        /// </summary>
        /// <param name="errors">持久的錯誤信息</param>
        /// <param name="id">id</param>
        /// <returns>是否成功</returns>
        bool Delete(ref ValidationErrors errors, string id);
        /// <summary>
        /// 刪除多個實體,中斷將回滾
        /// </summary>
        /// <param name="errors">持久的錯誤信息</param>
        /// <param name="deleteCollection">主鍵數組集合</param>
        /// <returns>是否成功</returns>
        bool Delete(ref ValidationErrors errors, string[] deleteCollection);
        /// <summary>
        /// 修改一個實體
        /// </summary>
        /// <param name="errors">持久的錯誤信息</param>
        /// <param name="model">模型</param>
        /// <returns>是否成功</returns>
        bool Edit(ref ValidationErrors errors, SysSampleModel model);
        /// <summary>
        /// 根據ID得到一個Model實體
        /// </summary>
        /// <param name="id">id</param>
        /// <returns>Model實體</returns>
        SysSampleModel GetById(string id);
        /// <summary>
        /// 判斷是否存在實體
        /// </summary>
        /// <param name="id">主鍵ID</param>
        /// <returns>是否存在</returns>
        bool IsExist(string id);
    }
}
ISysSampleBLL
using System;
using System.Collections.Generic;
using System.Linq;
using Apps.Models;
using Apps.Common;
using Apps.IBLL;
using Apps.IDAL;
using Apps.DAL;


namespace Apps.BLL
{
    public class SysSampleBLL :ISysSampleBLL
    {
        DBContainer db = new DBContainer();

        ISysSampleRepository Rep = new SysSampleRepository();

        /// <summary>
        /// 獲取列表
        /// </summary>
        /// <param name="pager">JQgrid分頁</param>
        /// <param name="queryStr">搜索條件</param>
        /// <returns>列表</returns>
        public List<SysSample> GetList(string queryStr)
        {
            
            IQueryable<SysSample> queryData =Rep.GetList(db);


            return queryData.ToList();
        }
       
        /// <summary>
        /// 建立一個實體
        /// </summary>
        /// <param name="errors">持久的錯誤信息</param>
        /// <param name="model">模型</param>
        /// <returns>是否成功</returns>
        public bool Create(SysSample entity)
        {
            try
            {
                if (Rep.Create(entity) == 1)
                {
                    return true;
                }
                else
                {
                   
                    return false;
                }
            }
            catch (Exception ex)
            {
                //ExceptionHander.WriteException(ex);
                return false;
            }
        }
        /// <summary>
        /// 刪除一個實體
        /// </summary>
        /// <param name="errors">持久的錯誤信息</param>
        /// <param name="id">id</param>
        /// <returns>是否成功</returns>
        public bool Delete(string id)
        {
            try
            {
                if (Rep.Delete(id) == 1)
                {
                    return true;
                }
                else
                {
                    return false;
                }
            }
            catch (Exception ex)
            {
                //ExceptionHander.WriteException(ex);
                return false;
            }
        }
      
        /// <summary>
        /// 修改一個實體
        /// </summary>
        /// <param name="errors">持久的錯誤信息</param>
        /// <param name="model">模型</param>
        /// <returns>是否成功</returns>
        public bool Edit(SysSample entity)
        {
            try
            {
                if (Rep.Edit(entity) == 1)
                {
                    return true;
                }
                else
                {
                    
                    return false;
                }

            }
            catch (Exception ex)
            {
                
                //ExceptionHander.WriteException(ex);
                return false;
            }
        }
        /// <summary>
        /// 判斷是否存在實體
        /// </summary>
        /// <param name="id">主鍵ID</param>
        /// <returns>是否存在</returns>
        public bool IsExists(string id)
        {
            if (db.SysSample.SingleOrDefault(a => a.Id == id) != null)
            {
                return true;
            }
            return false;
        }
        /// <summary>
        /// 根據ID得到一個實體
        /// </summary>
        /// <param name="id">id</param>
        /// <returns>實體</returns>
        public SysSample GetById(string id)
        {
            if (IsExist(id))
            {
                SysSample entity = Rep.GetById(id);


                return entity;
            }
            else
            {
                return null;
            }
        }

        /// <summary>
        /// 判斷一個實體是否存在
        /// </summary>
        /// <param name="id">id</param>
        /// <returns>是否存在 true or false</returns>
        public bool IsExist(string id)
        {
            return Rep.IsExist(id);
        }
    }
}
SysSampleBLL
@model IEnumerable<App.Models.SysSample>

@{
    Layout = null;
}

<!DOCTYPE html>

<html>
<head>
    <meta name="viewport" content="width=device-width" />
    <title>Index</title>
</head>
<body>
    <p>
        @Html.ActionLink("Create New", "Create")
    </p>
    <table>
        <tr>
            <th>
                @Html.DisplayNameFor(model => model.Name)
            </th>
            <th>
                @Html.DisplayNameFor(model => model.Age)
            </th>
            <th>
                @Html.DisplayNameFor(model => model.Bir)
            </th>
            <th>
                @Html.DisplayNameFor(model => model.Photo)
            </th>
            <th>
                @Html.DisplayNameFor(model => model.Note)
            </th>
            <th>
                @Html.DisplayNameFor(model => model.CreateTime)
            </th>
            <th></th>
        </tr>
    
    @foreach (var item in Model) {
        <tr>
            <td>
                @Html.DisplayFor(modelItem => item.Name)
            </td>
            <td>
                @Html.DisplayFor(modelItem => item.Age)
            </td>
            <td>
                @Html.DisplayFor(modelItem => item.Bir)
            </td>
            <td>
                @Html.DisplayFor(modelItem => item.Photo)
            </td>
            <td>
                @Html.DisplayFor(modelItem => item.Note)
            </td>
            <td>
                @Html.DisplayFor(modelItem => item.CreateTime)
            </td>
            <td>
                @Html.ActionLink("Edit", "Edit", new { id=item.Id }) |
                @Html.ActionLink("Details", "Details", new { id=item.Id }) |
                @Html.ActionLink("Delete", "Delete", new { id=item.Id })
            </td>
        </tr>
    }
    
    </table>
</body>
</html>
Index.cshtml

咱們往數據庫插入幾條記錄這時你應該看到效果了blog

相關文章
相關標籤/搜索