web-dev-qa-db-ja.com

最初にEntityFrameworkコードの視覚モデルをどのように作成しますか

here を見ると、この男がエンティティモデル図を表示していることに気付くでしょう。EntityFrameworkコードの最初のクラスからエンティティモデル図を作成する方法を知りたいです。

コードを見るだけで、すべてがどのようにリンクするかを思い出そうとするとイライラします。

54

Entity Frameworks Power Tools をインストールすると、ソリューションビューでコンテキストを右クリックし、[Entity Framework]をクリックして、[View Entity Data Model]を選択できます。

これにより、クラスからきちんとした図が作成されます。

56
Dennis Traub

エンティティデータモデル図は、EDMXファイルの視覚的な表示にすぎません。 Code-Firstモデルからこのようなダイアグラムを取得するには、そこからEDMXファイルを作成する必要があります。

using System.Data.Entity.Infrastructure; // namespace for the EdmxWriter class

using (var ctx = new MyContext())
{
    using (var writer = new XmlTextWriter(@"c:\Model.edmx", Encoding.Default))
    {
        EdmxWriter.WriteEdmx(ctx, writer);
    }
}

このコードはファイルを作成しますModel.edmx Visual Studioで開くことができます。モデル図が表示されます。 EDMXファイルは、現在のCode-Firstモデルのスナップショットです。コードでモデルを変更する場合、ダイアグラムにそれらの変更を反映する新しいEDMXファイルを作成する必要があります。

49
Slauma

スラウマに加えて、彼の答え。ダイアグラムのレイアウトを調整でき、作成後に毎回これをやり直したくない場合は、以前のEDMXファイルから新しいEDMXファイルにダイアグラムノードをコピーできます。

        string sPath = @"c:\Development\{0}";
        try
        {
            File.Copy(String.Format(sPath, "Model.edmx"), String.Format(sPath, "ModelTemplate.edmx"));
            File.Delete(String.Format(sPath, "Model.edmx"));
        }
        catch (Exception)
        {

            //no worry, file not found issues
        }

        using (var ctx = new ShopID.Models.ShopIDDb())
        {
            using (var writer = new XmlTextWriter(String.Format(sPath, "Model.edmx"), Encoding.Default))
            {
                EdmxWriter.WriteEdmx(ctx, writer);
            }
        }

        XmlDocument oldModel = new XmlDocument();
        oldModel.Load(String.Format(sPath, "ModelTemplate.edmx"));
        XmlDocument newModel = new XmlDocument();
        newModel.Load(String.Format(sPath, "Model.edmx"));

        var nsmgr = new XmlNamespaceManager(newModel.NameTable);
        nsmgr.AddNamespace("diagram", "http://schemas.Microsoft.com/ado/2009/11/edmx");
        XmlNode node = oldModel.SelectSingleNode("//diagram:Diagrams", nsmgr).ChildNodes[0];
        XmlNode newNode = newModel.SelectSingleNode("//diagram:Diagrams", nsmgr);
        XmlNode importNode = newNode.OwnerDocument.ImportNode(node, true);
        newModel.ImportNode(importNode, true);
        newNode.AppendChild(importNode);
        newModel.Save(String.Format(sPath, "Model.edmx"));
        File.Delete(String.Format(sPath, "ModelTemplate.edmx"));

//更新されたモデルはVisual Studioで開く準備ができています

4
Jaap

以前のEF Power Toolsで生成された図のレイアウトを保持するために、これは新しいものに存在するエンティティの位置や色などを引き継ぎ、追加はそのままにします。そうしないと、ダイアグラムに新しいエンティティが表示されません。

    static void CopyLayout(string srcFile, string destFile)
    {
        var oldModel = XDocument.Load(srcFile);
        var newModel = XDocument.Load(destFile);

        XNamespace edmxNs = "http://schemas.Microsoft.com/ado/2009/11/edmx";
        // find all entity shapes
        var oldEts = oldModel.Root.Descendants(edmxNs + "EntityTypeShape").Select(ets => ets).ToList();
        var newEts = newModel.Root.Descendants(edmxNs + "EntityTypeShape").Select(ets => ets).ToList();
        // replace any matching new with old
        foreach (var newEt in newEts)
        {
            var match = oldEts.SingleOrDefault(ot => ot.Attribute(@"EntityType").Value ==
                                                     newEt.Attribute(@"EntityType").Value);
            if (match != null)
                newEt.ReplaceAttributes(match.Attributes());
        }
        newModel.Save(destFile);
    }
0
Ian