.Net下EF的簡單實現

来源:https://www.cnblogs.com/chengrady/archive/2018/04/10/8780771.html
-Advertisement-
Play Games

1.連接SQLServer,創建資料庫TestDB; 2.添加EF引用,點擊工具-NuGet包管理器-管理解決方案的NuGet程式包, 搜索EntityFramework包,點擊安裝; 3.在Web.config中添加節點 其中Data Source為伺服器名,Initial Catalog為剛纔在 ...


1.連接SQLServer,創建資料庫TestDB;

 

2.添加EF引用,點擊工具-NuGet包管理器-管理解決方案的NuGet程式包,

搜索EntityFramework包,點擊安裝;

3.在Web.config中添加節點

<connectionStrings>
    <add connectionString="Data Source=(local);Initial Catalog=TestDB;Integrated Security=True" name="TestDBDAL" providerName="System.Data.SqlClient" />
  </connectionStrings>

  其中Data Source為伺服器名,Initial Catalog為剛纔在SQLServer中新建的資料庫名,name則是接下來在代碼中會使用到的名字,數據訪問層和資料庫之間的映射通過名稱實現的,ConnectionString(連接字元串)的名稱和數據訪問層的類名稱是相同的,都是TestDBDAL,因此會自動實現映射;

4.在Models文件下添加“PlayerModel”新類,為該類添加三個屬性,並引用System.ComponentModel.DataAnnotations命名空間,在PlayerID屬性上加上[Key]關鍵字標識主鍵;

using System.ComponentModel.DataAnnotations;

namespace WebApplication6.Models
{
    public class PlayerModel
    {
        [Key]
        public int PlayerID { get; set; }
        public string EnglishName { get; set; }
        public string ChineseName { get; set; }
    }
}

 

5.在項目下添加“DataAccessLayer”文件夾,並且添加“TestDBDAL.cs”新類,並且引用System.Data.Entity命名空間,使該類繼承DbContext類。定義映射關係,重寫OnModelCreating方法,其中Players為表名,運行時會自動生成在SQLServer中。再在該類下定義一個DbSet類型的新屬性,表示資料庫中能查詢到的所有play數據;

using System.Data.Entity;
using WebApplication6.Models;

namespace WebApplication6.DataAccessLayer
{
    public class TestDBDAL : DbContext
    {
        public DbSet<PlayerModel> Players { get; set; }
        protected override void OnModelCreating(DbModelBuilder modelBuilder)
        {
            modelBuilder.Entity<PlayerModel>().ToTable("Players");
            base.OnModelCreating(modelBuilder);
        }
    }
}

 

6.在HomeController.cs下的Index方法中添加獲取Players的方法;

  public ActionResult Index()
  {
    TestDBDAL testDBDAL = new TestDBDAL();
    List<PlayerModel> listPlayers = testDBDAL.Players.ToList();
    return View();
  }

 

7.運行項目;刷新TestDB資料庫,會看到已經新建了Players表,並且有3列屬性,其中PlayerID為主鍵。

8.為該表添加數據,並保存;

9.在Model文件夾下添加ListPlayerModel.cs新類,並且添加一個List類型的屬性;

using System.Collections.Generic;

namespace WebApplication6.Models
{
    public class ListPlayerModel
    {
        public List<PlayerModel> Employees { get; set; }
    }
}

10.將HomeController.cs下的Index方法改為獲取資料庫中players,並且傳遞給頁面;

public ActionResult Index()
{
  TestDBDAL testDBDAL = new TestDBDAL();
  ListPlayerModel listPlayerModel = new ListPlayerModel
  {
    Employees = testDBDAL.Players.ToList()
  };
  return View(listPlayerModel);
}

11.在頁面構造球員列表容器;

@using WebApplication6.Models;
@model ListPlayerModel
@{
    Layout = null;
}

<div>
    <table>
        <tr>
            <th>EnglishName</th>
            <th>ChineseName</th>
        </tr>
        @foreach (PlayerModel player in Model.Employees)
        {
            <tr>
                <td>@player.EnglishName</td>
                <td>@player.ChineseName</td>
            </tr>
        }
    </table>
</div>

12.運行代碼,頁面會出現資料庫中3個球員的屬性;

 插入數據

13.在index.cshtml後追加添加球員的div;

<div>
    Add New Player<br />
    <form action="/Home/AddNewPlayer" method="post">
        EnglishName:<input name="EnglishName" value="" type="text" /><br />
        ChineseName:<input name="ChineseName" value="" type="text" /><br />
        <input type="submit" value="Add" />
    </form>
</div>

14.在項目根目錄下添加BAL(業務邏輯處理)文件夾,併在文件夾下新添PlayerBAL.cs類,用來處理球員相關的業務邏輯。在該類下添加AddPlayer方法;

using WebApplication6.DataAccessLayer;
using WebApplication6.Models;

namespace WebApplication6.BAL
{
    public class PlayerBAL
    {
        public PlayerModel AddPlayer(PlayerModel player)
        {
            TestDBDAL testDBDAL = new TestDBDAL();
            testDBDAL.Players.Add(player);
            testDBDAL.SaveChanges();
            return player;
        }
    }
}

15.在HomeController下新添AddNewPlayer方法;

public ActionResult AddNewPlayer(PlayerModel p)
{
    PlayerBAL playerBAL = new PlayerBAL();
    playerBAL.AddPlayer(p);
    return RedirectToAction("Index");
}

其中RedirectToAction方法是重定向到XXX的方法,這裡是指添加完球員後再次重定向到Index.cshtml這個View;

16.運行代碼,併在View上添加球員,點擊Add,可得剛纔添加完的球員信息;

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 上接Spring框架學習筆記(一) IOC和DI區別 (1)IOC: 控制反轉,把對象創建交給spring進行配置 (2)DI: 依賴註入,向類裡面的屬性中設置值 (3)關係:依賴註入不能單獨存在,需要在ioc基礎之上完成操作 Spring整合web項目原理 1 載入spring核心配置文件 (1) ...
  • 以下是Java技術棧微信公眾號發佈的關於 Java 的技術乾貨,從以下幾個方面彙總。 ...
  • Eclipse設置了Tomacat後,項目信息會在你的workspace上,在Tomacat文件夾上是沒有的。但是通過設置是可以在Tomacat文件夾上存在的。 配置好伺服器後,先關閉伺服器,然後在Eclipse的伺服器上右鍵點擊open,則會出現Overview界面 然後選擇下麵選項,如圖,要當前 ...
  • 概述 UWP Community Toolkit Extensions 中有一個為TextBox 提供的 SurfaceDial 擴展 - SurfaceDialTextbox,本篇我們結合代碼詳細講解 SurfaceDialTextbox 的實現。 SurfaceDialTextbox 為 Tex ...
  • 《.NET 開源Protobuf-net從入門到精通》課程包含以下兩個部分: 一、.NET 開源Protobuf-net組件【數據存儲篇】 本次分享課程包含以下乾貨知識點: 1、什麼是Protobuffer? 2、Protobuffer應用場景介紹 3、為什麼Protocol Buffer性能這麼好 ...
  • net framework卸載 重裝 https://download.microsoft.com/download/E/4/1/E4173890-A24A-4936-9FC9-AF930FE3FA40/NDP461-KB3102436-x86-x64-AllOS-ENU.exe ...
  • 簡介 我們用C#來開發客戶端程式的時候,總會不可避免的需要調用外部程式或者訪問網站,本篇博客介紹了三種調用外部應用的方法,供參考 實現 第一種是利用shell32.dll,實現ShellExecute方法,該方法可同時打開本地程式、文件夾或者訪問網站,只要直接輸入路徑字元串即可, 如C:\Users ...
  • 為什麼要使用 ASP.NET Core? NET Core 剛發佈的時候根據介紹就有點心裡癢癢,微軟的尿性都懂的,新東西bug太多,現在2.0也發佈很久了,決定研究一下。 ASP.NET Core官方文檔https://docs.microsoft.com/en-us/aspnet/core/get ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...