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にこれをさせる方法、またはフィールドのカスタムシリアライザー/デシリアライザーを作成する方法はありますか?コードベース全体で使用すると、少なくとも自動のように見えますか?
ありがとう、
ダン