4

Code First モデルで Entity Framework を使用しています (ペット プロジェクトであり、単純なクラスを編集し、スキーマを自動的に更新するのが大好きです)。次のようなクラスがあります。

[Table("Polygons")]
public class Polygon
{
    public int PolygonId { get; set; }
    public String Texture { get; set; }

    public virtual ICollection<Point> Points { get; set; }
}

[Table("Points")]
public class Point
{
    public int PolygonId { get; set; }
    public double X { get; set; }
    public double Y { get; set; }
}

ポリゴンをデータベースに保存し、それらのテクスチャを照会できると便利です。一方、5,000 ポイントのポリゴンをデータベースに保存すると、それだけ多くの挿入を実行するのに永遠に時間がかかります。正直なところ、個々のポリゴンを取得する場合を除いて、ポイントをクエリすることはありません。

私がやりたいのは、「Point」クラスの「PolygonId」を取り除き、「Points」テーブルを取り除き、Polygon テーブルを次のようにすることです。

PolygonId int PK
Texture varchar(255)
Points XML

次に、ポイントを直接テーブルに保存される文字列にシリアル化しますが、シリアル化を解除してポイントの配列に戻します。EFにこれをさせる方法、またはフィールドのカスタムシリアライザー/デシリアライザーを作成する方法はありますか?コードベース全体で使用すると、少なくとも自動のように見えますか?

ありがとう、

ダン

4

1 に答える 1

7

別のプロパティを追加して、シリアル化を行うコードを記述する必要があると思います。

これはそれを行う必要があります:

[Table("Polygons")]
public class Polygon
{
    public int PolygonId { get; set; }
    public String Texture { get; set; }

    [NotMapped]
    public virtual ICollection<Point> Points { get; set; }

    [Column("Points")]
    [EditorBrowsable(EditorBrowsableState.Never)]
    [DebuggerBrowsable(DebuggerBrowsableState.Never)]
    public string PointsXml
    {
        get
        {
            var serializer = new XmlSerializer(typeof (List<Point>));
            using (var stringWriter = new StringWriter())
            {
                serializer.Serialize(stringWriter, Points.ToList());
                stringWriter.Flush();
                return stringWriter.ToString();
            }
        }
        set
        {
            var serializer = new XmlSerializer(typeof(List<Point>));
            using (var stringReader = new StringReader(value))
            {
                Points = (List<Point>) serializer.Deserialize(stringReader);
            }
        }
    }
}

および属性はオプションでEditorBrowsableありDebuggerBrowsable、XML プロパティが Intellisense (この型がライブラリから使用される場合) およびデバッガーに表示されないようにするだけです。

于 2013-07-25T13:24:40.750 に答える