国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

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

瀏覽:120日期:2022-06-09 11:16:37

有一段時間沒有更新博客了,趕上今天外面下雨,而且沒人約球,打算把最近對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ù)庫腳本也不可控,還不如自己提前設計好。DB first也好不了哪去,反向轉過來的代碼包含很多沒有用的文件,而且數(shù)據(jù)庫的更新還要重新走Model生成過程,簡直無法理解為什么會有這樣的設計。說了這么多,怎么解決呢?

數(shù)據(jù)庫和領域模型分開設計,按照對應關系映射字段,使用自定義鏈接字串,既不使用領域模型生成數(shù)據(jù)庫,也不用數(shù)據(jù)庫生成領域模型,示例代碼如下,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ù)庫的表的字段和領域模型的字段不對應,如何處理呢?比如本文的TTable表是在TTT  Schema下面的, 而其他表示設計在DBO下面,最方便的方式是使用fluent API, 具體代碼如請參見 TTableConfiguration Class和 OnModelCreating()方法,可配置的粒度非常細,比如可以配置領域模型和數(shù)據(jù)庫的哪個Schema的哪張表的哪一列對應,本文是將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. 如果需要多個操作同時成功或者失敗,需要手動開啟事務,具體代碼如下,

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)站設計的常用功能,一個簡單的真分頁查詢方法如下如下所示,

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();
    }
}

總結

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

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

標簽: ASP.NET
相關文章:
主站蜘蛛池模板: 99ri在线精品视频在线播放 | yy6080久久亚洲精品 | 黄色美女一级片 | 精品一区二区三区亚洲 | 国产免费久久精品 | 亚洲综合国产 | 免费观看国产网址你懂的 | 韩国三级日本三级香港三级黄 | 日本高清色本在线www游戏 | 亚洲三级视频 | 在线观看国产日本 | 国产精品亚洲欧美日韩区 | 欧美99| 久久精品国产一区二区三区 | 午夜欧美成人香蕉剧场 | 国产高清精品自在线看 | 亚洲国产精品久久卡一 | 国产成人永久免费视频 | 小屁孩和大人啪啪 | 欧美成人高清性色生活 | 天堂1在线观看 | 精品成人免费一区二区在线播放 | 国产高清一区二区 | 欧美一级毛片无遮无挡 | 亚洲激情黄色 | 成年女人在线视频 | 男女朋友做爽爽爽免费视频网 | 久久国产国内精品对话对白 | 91九色偷拍| 久久午夜网 | 亚洲欧美精品中文字幕 | 欧美日韩人成在线观看 | 国产黄毛片 | 全免费a级毛片免费看不卡 全免费毛片在线播放 | 成人全黄三级视频在线观看 | 久久99欧美| 一级一黄在线观看视频免费 | 毛片高清一区二区三区 | 亚洲一区二区三区高清视频 | 97在线公开视频 | 在线日本看片免费人成视久网 |