2

我有以下流程:

  1. 实体已创建
    • 当前上下文已关闭
  2. 更新
    • 通过属性设置器,也通过导航属性
  3. 放入 ViewState
    • 序列化,类型用 [Serializable] 属性标记)
  4. 从 ViewState 中读取
    • 反序列化
  5. 节省
    • 新的上下文是开放的

我应该如何正确创建实体:存根(默认构造函数)或DbSet<T>.Create()

我应该如何正确保存实体:DbSet<T>.Add()DbSet<T>.Attach()

我遇到了各种异常:

  • “违反 PRIMARY KEY 约束 'PK_currency_types'。无法在对象 'dbo.currency_types' 中插入重复键。重复键值为 (1)。语句已终止。”

  • “发生参照完整性约束违规:定义参照约束的属性值在关系中的主体对象和依赖对象之间不一致。”

我正在使用带有 DbContext Generator 扩展的 EF 4.3 Database First(我有数据库、设计器,但实体是自动生成的 POCO)。我是 EF 的新手,完全被卡住了。

更新:这是我的代码,它很简单,所以我没有从一开始就添加它:

public IStatement Create()
{
    using (var db = new ModelContainer())
    {
        // ID is auto-generated by db, INT IDENTITY(1,1)
        return new Statement();
        // or
        // return b.Statement.Create();
    }
}

// somewhere in the middle, for example:    
statement.Currency = db.Currency.Single(c => c.Name == "Euro");
statement.Amount = 1000;

public void Save(IStatement[] statement)
{
    using (var scope = new TransactionScope())
    using (var db = new ModelContainer())
    {
        foreach (var s in statement)
        {
            // statement has a number of navigation properties, i.e. referenced by FK entities

            // need to add/attach each back to db                
        }

        db.SaveChanges();
        scope.Complete();
    }
}

}

4

1 回答 1

0
var statement = new Statement();

using (var scope = new TransactionScope())
{
    var result = 0;
    foreach (var statement in arr.Cast<Statement>())
    {
        using (var db = new ModelContainer())
        {
            db.StatementTypes.Attach(statement.StatementType);
            db.Entry(statement.StatementType).State = EntityState.Unchanged;

            db.Currencies.Add(statement.Currency);
            db.Entry(statement.Currency).State = EntityState.Unchanged;

            db.Subjects.Attach(statement.Firm);
            db.Entry(statement.Firm).State = EntityState.Unchanged;

            db.Statement.Add(statement);

            db.SaveChanges();
        }
    }
    scope.Complete();
于 2012-06-09T19:19:32.770 回答