新しいインスタンスを作成し、リバースと一緒にlinqマッピングクラスを使用してメンバー値をコピーします。
など。
public static void CopyDataMembers(this DataContext dc,
object sourceEntity,
object targetEntity)
{
//get entity members
IEnumerable<MetaDataMember> dataMembers =
from mem in dc.Mapping.GetTable(sourceEntity.GetType())
.RowType.DataMembers
where mem.IsAssociation == false
select mem;
//go through the list of members and compare values
foreach (MetaDataMember mem in dataMembers)
{
object originalValue = mem.StorageAccessor.GetBoxedValue(targetEntity);
object newValue = mem.StorageAccessor.GetBoxedValue(sourceEntity);
//check if the value has changed
if (newValue == null && originalValue != null
|| newValue != null && !newValue.Equals(originalValue))
{
//use reflection to update the target
System.Reflection.PropertyInfo propInfo =
targetEntity.GetType().GetProperty(mem.Name);
propInfo.SetValue(targetEntity,
propInfo.GetValue(sourceEntity, null),
null);
// setboxedvalue bypasses change tracking - otherwise
// mem.StorageAccessor.SetBoxedValue(ref targetEntity, newValue);
// could be used instead of reflection
}
}
}
...か、DataContractSerializerを使用してクローンを作成することができます
internal static T CloneEntity<T>(T originalEntity) where T : someentitybaseclass
{
Type entityType = typeof(T);
DataContractSerializer ser =
new DataContractSerializer(entityType);
using (MemoryStream ms = new MemoryStream())
{
ser.WriteObject(ms, originalEntity);
ms.Position = 0;
return (T)ser.ReadObject(ms);
}
}
は、ルッククリストファーかかります。 – GONeale
すばらしい答え!これは機能している、私は反映を検討した。この解決策についてどう思いますか?私は、同じような操作を行うと期待していた組み込みのClone()を想定しています。 – GONeale
エンティティで読み取り専用のプロパティがある場合は、propInfo.SetValueを呼び出す前にプロパティにセッターがあるかどうかを確認する必要があります。 propInfo.GetSetMethod()がnull以外の値を返すかどうかを調べることができます。 – pbz