欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Entity?Framework使用DBContext實現(xiàn)增刪改查

 更新時間:2022年10月25日 17:38:21   作者:SolidMango  
這篇文章介紹了Entity?Framework使用DBContext實現(xiàn)增刪改查的方法,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下

有一段時間沒有更新博客了,趕上今天外面下雨,而且沒人約球,打算把最近對Entity Framework DBContext使用的心得梳理一下,早些時候在網(wǎng)上簡單查過,對于最新版本的EF并沒有類似的知識梳理類文章,希望對大家有所幫助。

1. 不要Code first, 也不要DB first

我為什么討厭Code first和DB first呢?首先Code first是先寫代碼,數(shù)據(jù)庫完全由代碼生成,開發(fā)階段尚可,一旦到了產(chǎn)品發(fā)布階段,如果需要添加字段,我們總不能用 visual studio去生產(chǎn)環(huán)境上去更新數(shù)據(jù)庫吧,聽起來就很可怕。而且另外的一個問題自動是生成的數(shù)據(jù)庫腳本也不可控,還不如自己提前設(shè)計好。DB first也好不了哪去,反向轉(zhuǎn)過來的代碼包含很多沒有用的文件,而且數(shù)據(jù)庫的更新還要重新走M(jìn)odel生成過程,簡直無法理解為什么會有這樣的設(shè)計。說了這么多,怎么解決呢?

數(shù)據(jù)庫和領(lǐng)域模型分開設(shè)計,按照對應(yīng)關(guān)系映射字段,使用自定義鏈接字串,既不使用領(lǐng)域模型生成數(shù)據(jù)庫,也不用數(shù)據(jù)庫生成領(lǐng)域模型,示例代碼如下,SQL Code 以 Destinations和TTable表為例:

CREATE TABLE [DBO].[Destinations]
(
    [DestinationId] [int] PRIMARY KEY NOT NULL,
    [Name] [nvarchar](max) NULL,
    [Country] [nvarchar](max) NULL,
    [Description] [nvarchar](max) NULL,
    [Photo] [varbinary](max) NULL
CREATE TABLE [TTT].[TTable]

(

 [Id] [int] PRIMARY KEY NOT NULL,

 [Name] [nvarchar](max) NULL

)

Model Class:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace Model
{
    public class Destination
    {
        public int DestinationId { get; set; }
        public string Name { get; set; }
        public string Country { get; set; }
        public string Description { get; set; }
        public byte[] Photo { get; set; }
        public List<Lodging> Lodgings { get; set; }
    }

    public class Lodging
    {
        public int LodgingId { get; set; }
        public string Name { get; set; }
        public string Owner { get; set; }
        public bool IsResort { get; set; }
        public Destination Destination { get; set; }
    }

    public class TTable
    {
        public int Id { get; set; }
        public string Name { get; set; }
    }
}

Connect String:

<connectionStrings>
    <add name="BAContext" connectionString="Data Source=(LocalDb)\MSSQLLocalDB;Initial Catalog=DataAccess.BreakAwayContext;Integrated Security=SSPI;" providerName="System.Data.SqlClient" />
  </connectionStrings>

DB Context:

using System.Data.Entity;
using System.Data.Entity.ModelConfiguration;
using Model;

namespace DataAccess
{
    public class TTableConfiguration : EntityTypeConfiguration<TTable>
    {
        public TTableConfiguration()
        {
            this.ToTable("TTable", "TTT");
        }
    }

    public class BreakAwayContext : DbContext
    {

        protected override void OnModelCreating(DbModelBuilder modelBuilder)
        {
            modelBuilder.Configurations.Add(new TTableConfiguration());
        }

        public BreakAwayContext(string connString) : base(connString)
        {
        }
        public DbSet<Destination> Destinations { get; set; }
        public DbSet<Lodging> Lodgings { get; set; }
        public DbSet<TTable> TTables { get; set; }
    }
}

2. 如果數(shù)據(jù)庫的表的字段和領(lǐng)域模型的字段不對應(yīng),如何處理呢?比如本文的TTable表是在TTT  Schema下面的, 而其他表示設(shè)計在DBO下面,最方便的方式是使用fluent API, 具體代碼如請參見 TTableConfiguration Class和 OnModelCreating()方法,可配置的粒度非常細(xì),比如可以配置領(lǐng)域模型和數(shù)據(jù)庫的哪個Schema的哪張表的哪一列對應(yīng),本文是將TTable 類的數(shù)據(jù)庫表配置為了TTT  Schema下的TTable表,

    public class TTableConfiguration : EntityTypeConfiguration<TTable>
    {
        public TTableConfiguration()
        {
            this.ToTable("TTable", "TTT");
        }
    }

3. 增刪該查自帶事物支持,具體代碼如下,

        public static int Insert()
        {
            var destination = new Destination
            {
                Country = "Chs",
                Description = "Chs is the language package",
                Name = "xsss"
            };
            using (var context = new BreakAwayContext(ConfigurationManager.ConnectionStrings["BAContext"].ConnectionString))
            {
                var rt = context.Destinations.Add(destination);
                context.SaveChanges();
                return rt.DestinationId;
            }
        }

        public static void Update(Destination destIn)
        {
            using (var context = new BreakAwayContext(ConfigurationManager.ConnectionStrings["BAContext"].ConnectionString))
            {
                var dest = context.Destinations.Where(a => a.DestinationId == destIn.DestinationId).Single();
                dest.Name = destIn.Name;
                context.SaveChanges();
            }
        }

        public static void Delete(int destId)
        {
            using (var context = new BreakAwayContext(ConfigurationManager.ConnectionStrings["BAContext"].ConnectionString))
            {
                var destination = new Destination() { DestinationId = destId };
                context.Destinations.Attach(destination);
                context.Destinations.Remove(destination);

                context.SaveChanges();
            }
        }


        public static Destination Query(int destId)
        {
            using (var context = new BreakAwayContext(ConfigurationManager.ConnectionStrings["BAContext"].ConnectionString))
            {
                IQueryable<Destination> dest = context.Destinations.Where(a => a.DestinationId == destId);

                return dest.Single();
            }
        }

4. 如果需要多個操作同時成功或者失敗,需要手動開啟事務(wù),具體代碼如下,

        public static void TransactionOps()
        {
            using (var context = new BreakAwayContext(ConfigurationManager.ConnectionStrings["BAContext"].ConnectionString))
            {
                using (var dbContextTransaction = context.Database.BeginTransaction())
                {
                    try
                    {
                        var destination = new Destination
                        {
                            Country = "Chs",
                            Description = "Chs is the language package",
                            Name = "xs2s"
                        };

                        var destId = context.Destinations.Add(destination);

                        context.SaveChanges();

                        context.Destinations.Attach(destId);
                        context.Destinations.Remove(destId);

                        context.SaveChanges();

                        dbContextTransaction.Commit();
                    }
                    catch (System.Exception ex)
                    {
                        dbContextTransaction.Rollback();
                        System.Console.WriteLine(ex.ToString());
                    }
                }
            }
        }

5. 分頁查詢是網(wǎng)站設(shè)計的常用功能,一個簡單的真分頁查詢方法如下如下所示,

        public static List<Destination> QueryPaging<TKey>(int pageIndex, int pageSize, Expression<Func<Destination, bool>> whereLambda, Expression<Func<Destination, TKey>> orderBy)
        {
            using (var context = new BreakAwayContext(ConfigurationManager.ConnectionStrings["BAContext"].ConnectionString))
            {
                return context.Destinations.Where(whereLambda).OrderBy(orderBy).Skip((pageIndex - 1) * pageSize).Take(pageSize).ToList();
            }
        }

總結(jié)

本文對最新版本的Entity Framework進(jìn)行增刪改查操作給出了詳盡的解釋,并且給出了數(shù)據(jù)庫和領(lǐng)域模型代碼分開設(shè)計的完整解決方案,同時介紹了手動數(shù)據(jù)庫表和領(lǐng)域模型映射,數(shù)據(jù)庫事務(wù)實現(xiàn),分頁查詢等常用功能,希望對大家有所幫助。

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接

相關(guān)文章

  • Remoting和Webservice的詳細(xì)介紹及區(qū)別

    Remoting和Webservice的詳細(xì)介紹及區(qū)別

    這篇文章主要介紹了Remoting和Webservice的詳細(xì)介紹及區(qū)別的相關(guān)資料,需要的朋友可以參考下
    2016-11-11
  • 一個簡單的ASP.NET Forms 身份認(rèn)證的實例方法

    一個簡單的ASP.NET Forms 身份認(rèn)證的實例方法

    當(dāng)訪問默認(rèn)首頁default.aspx時,會自動跳轉(zhuǎn)到login.aspx頁面上請求登錄,隨便輸入用戶名和密碼,點擊“登錄”按鈕,會回到首頁,并顯示當(dāng)前登錄的用戶名。
    2013-07-07
  • Entity Framework Core批處理SQL語句

    Entity Framework Core批處理SQL語句

    這篇文章介紹了Entity Framework Core批處理SQL語句的方法,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-02-02
  • ASP.NET 4.0配置文件中的ClientIDMode屬性詳解

    ASP.NET 4.0配置文件中的ClientIDMode屬性詳解

    在ASP.NET 4.0中的每個控件上都多了一個叫做ClientIDMode的屬性,本文主要介紹了ASP.NET 4.0配置文件中的ClientIDMode屬性詳解,非常具有實用價值,需要的朋友可以參考下
    2018-11-11
  • SQL Server數(shù)據(jù)庫連接 Web.config如何配置

    SQL Server數(shù)據(jù)庫連接 Web.config如何配置

    以下的文章主要描述的是Web.config正確配置SQL Server數(shù)據(jù)庫連接的實際擦步驟。我們以圖文結(jié)合的方式對其有個更好的說明,需要的朋友可以參考下
    2015-10-10
  • 把程序集安裝到全局程序集緩存中的步驟

    把程序集安裝到全局程序集緩存中的步驟

    最近兩天在看網(wǎng)絡(luò)編程中制作簡單的http服務(wù)器,其中用到把程序集安裝到全局程序集緩存中,自己嘗試了一下,記錄一下:(首先,對共享程序集安裝計算機管理員權(quán)限)
    2008-11-11
  • .net動態(tài)顯示當(dāng)前時間(客戶端javascript)

    .net動態(tài)顯示當(dāng)前時間(客戶端javascript)

    剛才在首頁看到 asp.net實現(xiàn)動態(tài)顯示當(dāng)前時間 這篇文章, 作者用Ajax實現(xiàn)類似時鐘的效果!
    2009-11-11
  • asp.net gridview自定義value值的代碼

    asp.net gridview自定義value值的代碼

    asp.net gridview自定義value值的代碼,需要的朋友可以參考下。
    2011-07-07
  • ASP.NET數(shù)據(jù)綁定之DataList控件實戰(zhàn)篇

    ASP.NET數(shù)據(jù)綁定之DataList控件實戰(zhàn)篇

    這篇文章主要為大家介紹了ASP.NET數(shù)據(jù)綁定中的DataList控件,DataList控件以表的形式呈現(xiàn)數(shù)據(jù),通過該控件,您可以使用不同的布局來顯示數(shù)據(jù)記錄,對DataList控件感興趣的小伙伴們可以參考一下
    2016-01-01
  • ASP.NET Core利用UrlFirewall對請求進(jìn)行過濾的方法示例

    ASP.NET Core利用UrlFirewall對請求進(jìn)行過濾的方法示例

    這篇文章主要給大家介紹了關(guān)于ASP.NET Core利用UrlFirewall對請求進(jìn)行過濾的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-05-05

最新評論