Le Vousmanager ne contient pas de ObjectStateEntry avec une référence à un objet

J'ai cru comprendre EF, notamment en termes de excrutiatingly simple CRUD, mais je me trompe peut-être.

J'ai un ObjectContext/modèle de Référentiel, et dans ce cas, un VatCode entité qui possède une collection de VatRates.

VatCode 1--* VatRate

Je veux pour fournir les fonctionnalités de CRUDing ces entités. C'est dans une application WPF, et "déconnecté" dans le fait que je ne suis pas holding DB connexions ouvertes unnecassarily. Je préfère le/la méthode de base de données access. Ceci est montré dans la suite de l'intégration du test:

    [TestMethod()]
    public void AddVatRateAndSaveVatCodeTest()
    {
        VatCode vatCode=null;
        DateTime expectedDateFrom = DateTime.Now.AddDays(1).Date;
        using (SopEntities sopEntities = EntitiesFactory.Create(Properties.Resources.ConnectionString))
        {
            VatRepository target = new VatRepository(sopEntities);
            vatCode = target.SingleOrDefault(q => q.Key == "X4");
            Assert.IsNotNull(vatCode);
        }

        //mimick offline editing/disconnect

        using (SopEntities sopEntities = EntitiesFactory.Create(Properties.Resources.ConnectionString))
        {
            VatRepository target = new VatRepository(sopEntities);


            vatCode.VatRates.Add(new VatRate()
                {
                    DateFrom=expectedDateFrom,
                    Rate=20
                });
            target.Attach(vatCode);
            target.SaveChanges();
        }

        using (SopEntities sopEntities=EntitiesFactory.Create(Properties.Resources.ConnectionString))
        {
            VatRepository vatRepository=new VatRepository(sopEntities);
            VatCode actual=vatRepository.SingleOrDefault(q=>q.Key=="X3");
            Assert.IsNotNull(actual);
            Assert.AreEqual(vatCode.VatRates.Count,actual.VatRates.Count);
            Assert.AreEqual(expectedDateFrom,actual.VatRates.OrderBy(q=>q.DateFrom).Last().DateFrom);
        }
    }

Le code est simple. Il récupère connu une entité existante et l'attribue à vatCode. Cette entité est ensuite passé autour dans le ViewModel sur l'INTERFACE utilisateur, et ré-enregistré. Dans ce test, je mimmick ce par l'ouverture d'un nouveau contexte. C'est exactement comment je le ferais dans l'INTERFACE utilisateur, de sorte que je suis la preuve ici.

Cependant, sur l'appel de l'attachement() la méthode de la vatRepository, qui a le corps de méthode suivant:

    public void Attach(TEntity entity)
    {
        if (entity == null)
            throw new ArgumentNullException("entity");

        _context.ObjectStateManager.ChangeObjectState(entity, System.Data.EntityState.Modified); //exception here
        _objectSet.Attach(entity);
    }

- Je obtenir de l'exception ci-dessous sur la ChangeObjectState méthode (que j'appelle parce que l'entité a été déconnecté du contexte original de la portée).

Système.InvalidOperationException est pas gérée par le code de l'utilisateur
Message=Le Vousmanager ne contient pas de ObjectStateEntry
avec une référence à un objet de type " Mac.Sop.De base.Les données.VatCode'.

J'ai pensé que peut-être mon XML dans le modèle EF n'était pas correct (compte tenu de la référence à la " Mac.Sop.De base.Les données.VatCode'), mais en regardant à travers elle que je ne trouve pas tous les problèmes et ces entités suivent des tendances similaires avec mes autres entités.

Mise à jour:
Mon modèle EF. Je ne trouve pas de référence à la " Mac.Sop.De base.Les données.VatCode':

<?xml version="1.0" encoding="utf-8"?>
<edmx:Edmx Version="2.0" xmlns:edmx="http://schemas.microsoft.com/ado/2008/10/edmx">
  <edmx:Runtime>
    <edmx:StorageModels>
    <Schema Namespace="Model.Store" Alias="Self" Provider="System.Data.SqlClient" ProviderManifestToken="2008" xmlns:store="http://schemas.microsoft.com/ado/2007/12/edm/EntityStoreSchemaGenerator" xmlns="http://schemas.microsoft.com/ado/2009/02/edm/ssdl">
        <EntityContainer Name="ModelStoreContainer">
          <EntitySet Name="MacsSop_VATCode" EntityType="Model.Store.MacsSop_VATCode" store:Type="Tables" Schema="dbo" />
          <EntitySet Name="MacsSop_VATRate" EntityType="Model.Store.MacsSop_VATRate" store:Type="Tables" Schema="dbo" />
          <AssociationSet Name="FK_MacsSop_VATRate_MacsSop_VATCode" Association="Model.Store.FK_MacsSop_VATRate_MacsSop_VATCode">
            <End Role="MacsSop_VATCode" EntitySet="MacsSop_VATCode" />
            <End Role="MacsSop_VATRate" EntitySet="MacsSop_VATRate" />
          </AssociationSet>
        </EntityContainer>
        <EntityType Name="MacsSop_VATCode">
          <Key>
            <PropertyRef Name="Key" />
          </Key>
          <Property Name="Key" Type="varchar" Nullable="false" MaxLength="3" />
          <Property Name="Name" Type="nvarchar" Nullable="false" MaxLength="128" />
        </EntityType>
        <EntityType Name="MacsSop_VATRate">
          <Key>
            <PropertyRef Name="ID" />
          </Key>
          <Property Name="ID" Type="int" Nullable="false" StoreGeneratedPattern="Identity" />
          <Property Name="Key" Type="varchar" Nullable="false" MaxLength="3" />
          <Property Name="DateFrom" Type="datetime" Nullable="false" />
          <Property Name="Rate" Type="decimal" Nullable="false" Scale="2" />
        </EntityType>
        <Association Name="FK_MacsSop_VATRate_MacsSop_VATCode">
          <End Role="MacsSop_VATCode" Type="Model.Store.MacsSop_VATCode" Multiplicity="1" />
          <End Role="MacsSop_VATRate" Type="Model.Store.MacsSop_VATRate" Multiplicity="*" />
          <ReferentialConstraint>
            <Principal Role="MacsSop_VATCode">
              <PropertyRef Name="Key" />
            </Principal>
            <Dependent Role="MacsSop_VATRate">
              <PropertyRef Name="Key" />
            </Dependent>
          </ReferentialConstraint>
        </Association>
      </Schema></edmx:StorageModels>
    <!-- CSDL content -->
    <edmx:ConceptualModels>
      <Schema Namespace="Model" Alias="Self" xmlns:annotation="http://schemas.microsoft.com/ado/2009/02/edm/annotation" xmlns="http://schemas.microsoft.com/ado/2008/09/edm">
        <EntityContainer Name="SopEntities" annotation:LazyLoadingEnabled="true" >
          <EntitySet Name="VatCodes" EntityType="Model.VatCode" />
          <EntitySet Name="VatRates" EntityType="Model.VatRate" />
          <AssociationSet Name="FK_MacsSop_VATRate_MacsSop_VATCode" Association="Model.FK_MacsSop_VATRate_MacsSop_VATCode">
            <End Role="MacsSop_VATCode" EntitySet="VatCodes" />
            <End Role="MacsSop_VATRate" EntitySet="VatRates" />
          </AssociationSet>
        </EntityContainer>
        <EntityType Name="VatCode">
          <Key>
            <PropertyRef Name="Key" />
          </Key>
          <Property Type="String" Name="Key" Nullable="false" MaxLength="3" FixedLength="false" Unicode="false" />
          <Property Type="String" Name="Name" Nullable="false" MaxLength="128" FixedLength="false" Unicode="true" />
          <NavigationProperty Name="VatRates" Relationship="Model.FK_MacsSop_VATRate_MacsSop_VATCode" FromRole="MacsSop_VATCode" ToRole="MacsSop_VATRate" />
        </EntityType>
        <EntityType Name="VatRate">
          <Key>
            <PropertyRef Name="ID" />
          </Key>
          <Property Type="Int32" Name="ID" Nullable="false" annotation:StoreGeneratedPattern="Identity" />
          <Property Type="String" Name="Key" Nullable="false" MaxLength="3" FixedLength="false" Unicode="false" />
          <Property Type="DateTime" Name="DateFrom" Nullable="false" />
          <Property Type="Decimal" Name="Rate" Nullable="false" Precision="18" Scale="2" />
          <NavigationProperty Name="VatCode" Relationship="Model.FK_MacsSop_VATRate_MacsSop_VATCode" FromRole="MacsSop_VATRate" ToRole="MacsSop_VATCode" />
        </EntityType>
        <Association Name="FK_MacsSop_VATRate_MacsSop_VATCode">
          <End Type="Model.VatCode" Role="MacsSop_VATCode" Multiplicity="1" />
          <End Type="Model.VatRate" Role="MacsSop_VATRate" Multiplicity="*" />
          <ReferentialConstraint>
            <Principal Role="MacsSop_VATCode">
              <PropertyRef Name="Key" />
            </Principal>
            <Dependent Role="MacsSop_VATRate">
              <PropertyRef Name="Key" />
            </Dependent>
          </ReferentialConstraint>
        </Association>
      </Schema>
    </edmx:ConceptualModels>
    <!-- C-S mapping content -->
    <edmx:Mappings>
      <Mapping Space="C-S" xmlns="http://schemas.microsoft.com/ado/2008/09/mapping/cs">
        <EntityContainerMapping StorageEntityContainer="ModelStoreContainer" CdmEntityContainer="SopEntities" >
          <EntitySetMapping Name="VatCodes">
            <EntityTypeMapping TypeName="Model.VatCode">
              <MappingFragment StoreEntitySet="MacsSop_VATCode">
                <ScalarProperty Name="Name" ColumnName="Name" />
                <ScalarProperty Name="Key" ColumnName="Key" />
              </MappingFragment>
            </EntityTypeMapping>
          </EntitySetMapping>
          <EntitySetMapping Name="VatRates">
            <EntityTypeMapping TypeName="Model.VatRate">
              <MappingFragment StoreEntitySet="MacsSop_VATRate">
                <ScalarProperty Name="Rate" ColumnName="Rate" />
                <ScalarProperty Name="DateFrom" ColumnName="DateFrom" />
                <ScalarProperty Name="Key" ColumnName="Key" />
                <ScalarProperty Name="ID" ColumnName="ID" />
              </MappingFragment>
            </EntityTypeMapping>
          </EntitySetMapping>
        </EntityContainerMapping>
      </Mapping>
    </edmx:Mappings>
  </edmx:Runtime>

</edmx:Edmx>

Cela doit fonctionner dans ce mode déconnecté et il doit être possible que WCF/ASP.NET implémentations de ce modèle existent bien sûr!

OriginalL'auteur Program.X | 2012-05-03