日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

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

Entity Framework使用DBContext實現增刪改查

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

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

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

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

數據庫和領域模型分開設計,按照對應關系映射字段,使用自定義鏈接字串,既不使用領域模型生成數據庫,也不用數據庫生成領域模型,示例代碼如下,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. 如果數據庫的表的字段和領域模型的字段不對應,如何處理呢?比如本文的TTable表是在TTT  Schema下面的, 而其他表示設計在DBO下面,最方便的方式是使用fluent API, 具體代碼如請參見 TTableConfiguration Class和 OnModelCreating()方法,可配置的粒度非常細,比如可以配置領域模型和數據庫的哪個Schema的哪張表的哪一列對應,本文是將TTable 類的數據庫表配置為了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. 分頁查詢是網站設計的常用功能,一個簡單的真分頁查詢方法如下如下所示,

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進行增刪改查操作給出了詳盡的解釋,并且給出了數據庫和領域模型代碼分開設計的完整解決方案,同時介紹了手動數據庫表和領域模型映射,數據庫事務實現,分頁查詢等常用功能,希望對大家有所幫助。

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

標簽: ASP.NET
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
91综合网人人| 日韩高清电影一区| 久久99视频| 国产伦理久久久久久妇女| 欧美专区一区| 国产精品伦一区二区| 国产精品久久久免费| 老鸭窝一区二区久久精品| 久久精品色播| av资源中文在线天堂| 日韩中文在线电影| 天堂√8在线中文| 欧美日韩尤物久久| 91成人精品| 午夜国产欧美理论在线播放| 午夜国产一区二区| 亚洲三级网址| 国产日韩欧美高清免费| 精品一区视频| 欧美aa在线观看| 欧美亚洲在线日韩| 欧美69视频| 国产探花在线精品一区二区| 欧美日韩国产免费观看视频| 午夜宅男久久久| 国产亚洲精品美女久久| 久久男人av资源站| 国产欧美日韩综合一区在线播放| 日韩av自拍| 99在线观看免费视频精品观看| 日韩一区二区免费看| 欧美精品羞羞答答| 一区二区国产在线观看| 日本va欧美va精品发布| 国产一区二区三区不卡视频网站| 亚洲二区视频| 日本亚洲欧美天堂免费| 久久成人高清| 激情婷婷亚洲| 日韩av中文在线观看| 不卡一二三区| 亚洲欧洲美洲国产香蕉| 精品久久久网| 欧美特黄a级高清免费大片a级| 国产美女一区| 国产亚洲精品精品国产亚洲综合| 91亚洲国产| 免费日韩精品中文字幕视频在线| 国产精品三p一区二区| 久久国产毛片| 偷拍亚洲精品| 伊人久久国产| 亚洲精品乱码久久久久久蜜桃麻豆| 国产精品欧美在线观看| 欧美中文一区二区| 欧美亚洲国产日韩| 亚洲高清久久| 国产午夜久久av| 精品1区2区3区4区| 麻豆免费精品视频| 激情综合激情| 久久丁香四色| 久色成人在线| 樱桃视频成人在线观看| 婷婷精品久久久久久久久久不卡| 亚洲免费观看高清完整版在线观| 美日韩精品视频| 日韩精品亚洲aⅴ在线影院| 99国产精品私拍| 亚洲欧美日韩高清在线| 国产精品欧美在线观看| 国产精品二区不卡| 天堂中文av在线资源库| 午夜av成人| 精品一区二区三区中文字幕| 成人台湾亚洲精品一区二区 | 国产欧美精品久久| 蜜桃国内精品久久久久软件9| 国产精品视频一区二区三区综合| 亚洲综合丁香| av在线日韩| 免费国产亚洲视频| 午夜精品成人av| 国产精品免费99久久久| 欧美 日韩 国产精品免费观看| 你懂的国产精品| 亚洲tv在线| 影视先锋久久| 在线看片国产福利你懂的| 日韩精品成人| 老司机久久99久久精品播放免费| 日韩欧美一区二区三区免费观看| 国产欧美日韩精品一区二区三区 | 免费精品视频最新在线| 欧美肉体xxxx裸体137大胆| 国产aⅴ精品一区二区四区| 欧美偷窥清纯综合图区| 一区二区三区四区在线观看国产日韩 | 久久99国产精品视频| 四虎成人精品一区二区免费网站| 蜜臀av免费一区二区三区| 97se综合| 国产伊人久久| 高清av不卡| 日韩成人精品一区二区三区 | 久久香蕉精品香蕉| 日韩成人亚洲| 深夜福利亚洲| 99成人在线| 91视频一区| 亚洲精品在线二区| 91精品电影| 91精品一区国产高清在线gif| 精品国产一区二区三区噜噜噜| 欧美日韩亚洲三区| 91成人在线| 日韩精品亚洲aⅴ在线影院| 亚洲视频国产| 在线国产精品一区| 中文字幕日韩亚洲| 亚洲精品成人一区| 亚州国产精品| 久热精品在线| 免费视频最近日韩| 男人的天堂久久精品| 午夜久久美女| 国产精品日韩| 免费人成在线不卡| 日韩1区2区3区| 日韩国产一区二| 日韩不卡一区二区三区| 91综合久久爱com| 欧美亚洲一区二区三区| 国产精品天天看天天狠| 精品国产午夜| 色婷婷色综合| 国产精品115| 国产精品精品| 最新中文字幕在线播放| 亚洲日本网址| 99国产精品99久久久久久粉嫩| 蜜桃91丨九色丨蝌蚪91桃色| 欧美国产不卡| 成人羞羞视频播放网站| 亚洲精品中文字幕乱码| 亚洲深夜福利在线观看| 国产日韩在线观看视频| 国产在线不卡一区二区三区| 精品免费av在线| 国产精品丝袜在线播放| 久久精品伊人| 亚洲精品美女91| 亚洲啊v在线免费视频| 九一成人免费视频| 日韩精品视频网| 国产在线看片免费视频在线观看| 香蕉视频成人在线观看| 成人在线免费观看网站| 免费成人av在线播放| 免费黄色成人| 国产精品一线天粉嫩av| 欧美激情五月| 九九色在线视频| 国产亚洲一区在线| 婷婷成人av| 国内自拍视频一区二区三区| 视频福利一区| 蜜桃视频在线观看一区二区| 亚洲久久视频| 久久wwww| 久久在线免费| 日韩av在线免费观看不卡| 欧美好骚综合网| 老鸭窝亚洲一区二区三区| 欧美日韩亚洲一区二区三区在线| 天堂√中文最新版在线| 亚洲a级精品| 黑人精品一区| 久久亚洲欧洲| 丰满少妇一区| 模特精品在线| 精品欧美日韩精品| 午夜一级久久| 国产精品美女在线观看直播| 欧美成人高清| 国产调教精品| 99国产精品视频免费观看一公开 | 91视频精品| 亚洲专区视频| 亚洲最新无码中文字幕久久| 欧美精品激情| 国产精品美女久久久久久不卡| 99久久精品网站| 在线一区二区三区视频| 欧美亚洲人成在线| 999久久久精品国产| 久久精品国产一区二区| 亚洲a成人v| 亚洲精品中文字幕乱码| 国产在线|日韩|