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

您的位置:首頁技術(shù)文章
文章詳情頁

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

瀏覽:325日期: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ù)庫腳本也不可控,還不如自己提前設(shè)計(jì)好。DB first也好不了哪去,反向轉(zhuǎn)過來的代碼包含很多沒有用的文件,而且數(shù)據(jù)庫的更新還要重新走M(jìn)odel生成過程,簡直無法理解為什么會有這樣的設(shè)計(jì)。說了這么多,怎么解決呢?

數(shù)據(jù)庫和領(lǐng)域模型分開設(shè)計(jì),按照對應(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è)計(jì)在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è)計(jì)的常用功能,一個簡單的真分頁查詢方法如下如下所示,

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è)計(jì)的完整解決方案,同時介紹了手動數(shù)據(jù)庫表和領(lǐng)域模型映射,數(shù)據(jù)庫事務(wù)實(shí)現(xiàn),分頁查詢等常用功能,希望對大家有所幫助。

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

標(biāo)簽: ASP.NET
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
热久久国产精品| 亚洲啊v在线| 色吊丝一区二区| 国产精品中文字幕制服诱惑| 亚洲三级av| 日韩精品欧美成人高清一区二区| 亚洲作爱视频| 99国产成+人+综合+亚洲欧美| 欧产日产国产精品视频| 福利一区和二区| 高清精品久久| 好吊日精品视频| 国产精品欧美大片| 欧美激情三区| 电影天堂国产精品| 亚洲欧美日韩国产综合精品二区| 蜜桃视频免费观看一区| 欧美日本精品| 国产精品男女| 电影91久久久| 国产精品日韩久久久| 日本久久一区| 中文在线免费视频| 老鸭窝毛片一区二区三区| 国产视频一区二| 新版的欧美在线视频| 亚洲激情av| 午夜性色一区二区三区免费视频| 91亚洲精品视频在线观看| 精品欧美日韩精品| 欧美日韩在线二区| 中文字幕亚洲影视| 国产中文字幕一区二区三区| 国产成人免费| 亚洲日本免费电影| jizzjizz中国精品麻豆| 国产一区白浆| 日韩免费在线| 欧美亚洲色图校园春色| 亚洲女同一区| 中文在线资源| 国产精品一区二区中文字幕| 红桃视频欧美| 另类中文字幕国产精品| 国产精品视频一区视频二区| 羞羞答答国产精品www一本| 在线中文字幕播放| 国产精品毛片aⅴ一区二区三区| 99久久亚洲精品蜜臀| 日韩一区精品视频| 久久国产精品99国产| 亚洲精品**中文毛片| 国产精品极品国产中出| 欧美特黄一区| 性感美女一区二区在线观看| 欧美激情99| 91成人在线| 日本一区二区中文字幕| 夜久久久久久| 99视频一区| 在线成人直播| 久久高清免费| 日本а中文在线天堂| 91欧美精品| 亚洲在线国产日韩欧美| 婷婷激情综合| 性欧美长视频| 日韩在线观看一区二区| 日本麻豆一区二区三区视频| 婷婷成人在线| 日韩欧美午夜| 亚洲午夜一级| 麻豆精品网站| 婷婷亚洲成人| 国产午夜精品一区在线观看| 欧美日韩午夜电影网| 国产日产精品_国产精品毛片| 国产欧美日韩影院| 日本不卡视频在线观看| 亚洲精品美女91| 国产三级一区| 国产一区二区三区天码| 亚洲天堂免费电影| 久久高清免费观看| 欧美专区一区| 久久uomeier| 亚洲欧美日韩一区在线观看| 日韩有码av| 欧美日韩在线二区| 午夜亚洲福利| 91精品日本| 日本久久精品| 日韩中文字幕91| 日本午夜精品久久久| 精品深夜福利视频| 性欧美69xoxoxoxo| 欧美亚洲三级| 91精品国产调教在线观看| 亚欧洲精品视频在线观看| 精品美女在线视频| 日韩制服丝袜先锋影音| 国产aⅴ精品一区二区三区久久| 午夜电影亚洲| 精品国产欧美日韩| 亚洲欧美日韩国产| 国产粉嫩在线观看| 日韩精选在线| 黄色不卡一区| 欧美日韩中文| 欧美日韩国产一区精品一区| 欧美成a人片免费观看久久五月天| 亚洲精品少妇| 一区二区三区视频免费观看| 91成人在线| 中文一区一区三区免费在线观 | 日韩av一区二区三区| 免费观看久久av| 成人污污视频| 日韩一区免费| 视频一区中文字幕国产| 桃色av一区二区| 国产欧美日韩免费观看| 亚洲精品人人| 亚洲综合电影一区二区三区| 日本精品在线中文字幕| 欧美日韩亚洲三区| 亚洲毛片在线| 日韩国产综合| 免费在线日韩av| 久久国产三级| 欧美久久香蕉| 国产精品www994| 久久亚洲道色| 国产高清精品二区| 久久99性xxx老妇胖精品| 国产乱人伦精品一区| 欧美亚洲三级| 国产精品一卡| 大香伊人久久精品一区二区| 久久精品国产免费| 亚洲va中文在线播放免费| 日韩国产一区二区| 激情综合自拍| 男女男精品视频网| 日韩精品一区二区三区免费视频| 日韩av影院| 麻豆91精品91久久久的内涵| 91青青国产在线观看精品| 久久精品动漫| 日本欧美不卡| 亚洲免费精品| 蜜桃视频一区二区| 国产欧美69| 欧美成人精品三级网站| 最新亚洲激情| 欧美日本久久| 欧美精品高清| 日韩精品免费一区二区夜夜嗨| 激情久久一区二区| 国产午夜精品一区二区三区欧美 | 久久久久久久久丰满| 天堂精品久久久久| 日本久久黄色| 日本不卡视频一二三区| 精品国模一区二区三区| 日韩精品电影一区亚洲| 日韩精品91| 欧美日本不卡高清| 日韩一级欧洲| 国产精品yjizz视频网| 免费亚洲婷婷| 免费日韩视频| 久久亚洲国产精品尤物| 欧美日韩视频一区二区三区| 国产精品久av福利在线观看| 日韩在线短视频| 亚洲精品无播放器在线播放| 欧美久久天堂| 日韩精品视频在线看| 欧美精品一区二区三区精品| 久久久久97| 国产乱码精品一区二区三区四区 | 欧美在线亚洲| 精品亚洲自拍| 久久精品99国产国产精| 日韩精品一二三| 精品成av人一区二区三区| 国产精品国产三级在线观看| 久久xxxx| 视频在线在亚洲| 欧美日韩中出| 久久婷婷一区| 欧美日韩中出| 尤物在线精品| av资源中文在线| 精品在线网站观看| 国产在视频一区二区三区吞精| 亚洲人成毛片在线播放女女| 久久国产亚洲精品| 亚洲精品国产嫩草在线观看|