日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

EF 笔记

發布時間:2024/10/12 编程问答 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 EF 笔记 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

1. 類與類之間通過引用,即為導航屬性,來建立關系,CF會根據引用的屬性類型,將其映射為一對一,或一對多,或多對多的關系

  表名生成方式:1)類名的復數(默認的)2)使用特性[Table("TableName")]指定

  3)不想使用表名復數時,可以在OnModelCreating 中加入modelBuilder.Conventions.Remove<PluralizingTableNameConvention>();?????

  外鍵生成方式:1)表名+ID(默認的)2)使用特性[ForeignKey("FKName")]指定

2. 當一個類在加載數據時,默認不會加載外鍵表數據(懶惰加載:導航屬性由virtual修飾和?Configuration.LazyLoadingEnabled?=?true)

  其它兩種加載方式:

  貪婪加載:?context.Table1.Include("Table2"), 生成SQL語句,只有一條,相對復雜點

  顯示加載: context.Entry(context.Table1.Single()).Collection(d=>d.Table2).Load();?

      • 注意結合 Query() 和 IsLoaded 的使用,Collection 是一對多的引用,一對一引用,則使用 Reference
      • 執行Load()之后,所有有關Table2的操作都會在內存中進行
      • 這里生成的是兩條SQL,執行兩次查詢

3. 當兩類之間多次引用對方時,則會建立組合外鍵,如何確定關系時,則可在一個類的引用屬性上使用InverseProperty("另一類的引用屬性名")

4. 當兩類之間互相引用對方的類集合時,CF將自動生成包含兩類主鍵的中間表,為兩表建立一個多對多的關系

5. 當兩類之間互相引用對方的類時,則需在當前類的主鍵上,設置特性,并把 ForeignKey 指向其引用屬性名(另一個類的名稱,兩表之間為一對一關系

  [Key,ForeginKey("另一個類的名稱")]

  public Guid 主鍵名稱 //標識特性Key時,其名稱命名可以不用與另一個類的名稱作為前綴

6. one to one:在設置外鍵對象的時候,其它外鍵的對象跟主表對象 必須都來之同一個上下文

 void AddProject(){ 

 NSContext context = new NSContext();

?? IRepository<EmailConfig> emailconfigDAL = new NS.Context.EmailConfigDAL(context);//必須傳進去,如果不是同一個上下文,將會報 Cannot insert duplicate key in object “PK_EmailConfig”

???EmailConfig emailconfig = emailconfigDAL.FindAll(new EmailConfig { ID = model.EmailConfig_ID.Value }).First();
?? model.ID = Guid.NewGuid();
???model.EmailConfig = emailconfig;//這里
?? model.CreateDate = DateTime.Now;
???model.WorkStatus = model.WorkStatus;
?? context.Projects.Add(model);
?? context.SaveChanges();

}

7.PM> Enable-Migrations?

8. 數據庫配置,通過 Fluent API 和 Data Annotation 這兩種方式來配置的,?在實際操作中,我們二選一就行

  Data Annotation:通過特性的形式來配置,如:

    

KeyAttribute

StringLengthAttribute

MaxLengthAttribute

ConcurrencyCheckAttribute

RequiredAttribute

TimestampAttribute

ComplexTypeAttribute

ColumnAttribute  

TableAttribute  

InversePropertyAttribute?

ForeignKeyAttribute 

DatabaseGeneratedAttribute?  

NotMappedAttribute ?  

?

  Fluent API:通過在DbContext中的重寫 OnModelCreating 來配置的,為避免該方法體過度膨脹,可以為各個類配置相應映射類,如:

    

public class 類的名稱Map : EntityTypeConfiguration<類的名稱>{public 類的名稱Map(){Property(d => d.Name).IsRequired();// 這只配置一個要求,如有其它,則可以在自身的映射類中配置}}

  然后,

protected override void OnModelCreating(DbModelBuilder modelBuilder){modelBuilder.Configurations.Add(new 類的名稱Map());// 這只體現一行代碼}

如下進行配置,如果有多個配置的話,則會膨脹
protected override void OnModelCreating(DbModelBuilder modelBuilder)
??????? {
??????????? modelBuilder.Entity
<類的名稱>().Property(d => d.Name).IsRequired();
??????? }

?  另外如果不想表與表之間存在級聯刪除公約,則可以加入

   modelBuilder.Conventions.Remove<OneToManyCascadeDeleteConvention>();

   還有其它可以移除的公約(根據需要而定),如:

   OneToOneConstraintIntroductionConvention,IncludeMetadataConvention 等等

?

9.?There is already an open DataReader associated with this Command which must be closed first. 異常

  由于導航屬性 xxx(具有 virtual 和?LazyLoadingEnabled?=?true), 在 connectionString 中沒有設置?MultipleActiveResultSets=true 引起的

  MARS is compatible with SQL Server 2005 and above

10. 樂觀并發控制:

  行版本控制:Version 字段數據類型必須為 byte[] , 然后?this.Property(s?=>?s.Version).IsRowVersion() ,在生成的SQL語句中,將會附帶 version='#########' 作為條件,

        如:update table set name='xxx' where id=1 and version='########'

  字段控制: 任意字段都可以這樣配置?this.Property(s?=>?s.Email).IsConcurrencyToken(),在生成的SQL語句中,將會附帶舊值作為條件,

       ?如: update table set Email='新值' where id=1 and Email='舊值'

轉載于:https://www.cnblogs.com/yipeng-yu/archive/2013/05/18/3085109.html

總結

以上是生活随笔為你收集整理的EF 笔记的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 亚洲黄色免费电影 | 毛片网站免费 | 日韩在线播放av | 亚洲666| 欧美精品一级 | 国产男男gay体育生白袜 | 高h调教冰块play男男双性文 | 人妻无码久久精品人妻 | 国产亚洲毛片 | 亚洲精品国产精华液 | 在线观看麻豆视频 | 午夜理伦三级做爰电影 | 色呦呦影院| 毛片一卡二卡 | 成人做爰69片免费观看 | 男女做爰猛烈高潮描写 | 怡红院成人影院 | 噜噜噜亚洲色成人网站 | 男人的天堂一区二区 | 91av毛片 | 狠狠香蕉| 欧美日韩精品一区二区 | 久久国产精品影院 | 非洲黄色大片 | 国产又黄又硬又粗 | av久热 | 中文字幕乱码视频 | 成人国产免费视频 | 人妻偷人精品一区二区三区 | 黄床大片| 精品一区二区三区四区 | 偷偷操不一样 | 国产特级片| 午夜在线精品偷拍 | 91日韩一区二区 | 骚鸭av| av色区| 色污网站 | 亚洲av无码潮喷在线观看 | 黑人巨大国产9丨视频 | 久久不卡 | 成人小视频在线观看 | 叶全真三级 | 欧洲激情网 | 亲嘴扒胸摸屁股激烈网站 | 欧美v亚洲 | 亚洲偷自| 美女靠逼app | 国产福利视频一区二区三区 | 2025国产精品视频 | 人操人爽 | 日韩有码中文字幕在线 | 国产情侣激情 | 一区二区三区久久久 | 欧美精品高清 | 午夜婷婷色 | 天堂在线视频网站 | 亚洲乱色熟女一区二区 | 成年人看的视频网站 | 成人超碰 | www.成人网| 日韩在线观看中文字幕 | 91精品国产色综合久久不卡98 | 日韩影视在线 | 人妻精品久久久久中文 | xxxwww在线观看| 亚洲午夜一区 | 亚洲国产精品美女 | 日本亚洲在线 | 男人插入女人阴道视频 | 亚洲欧美精品 | 亚洲免费视频一区二区 | 亚洲av成人精品日韩在线播放 | av999 | 欧美日韩一区不卡 | 久草免费在线观看视频 | 亚洲精品高清视频 | 欧美色图第一页 | 人人妻人人澡人人爽欧美一区双 | 日韩91视频 | 免费看的黄网站 | 久久久久久久久久久久久久av | 一眉道姑| www.com在线观看 | 日韩亚洲区| 中文资源在线观看 | 午夜影院免费在线观看 | 尤物视频在线观看视频 | 欧美偷拍视频 | 美女脱了裤子让男人桶 | 深夜福利一区二区 | 欧美午夜一区二区三区 | 色94色欧美| 涩涩97| 亚洲一二三级 | 四虎网址大全 | 九九精品热 | 亚洲乱码av | 精品国产污污免费网站入口 |