我想使用 Linq to SQL 向数据库添加一些行,但我想在添加行之前进行“自定义检查”,以了解是否必须添加、替换或忽略传入行。
我希望保持客户端和数据库服务器之间的流量尽可能低,并最大限度地减少查询数量。
为此,我希望获取验证所需的尽可能少的信息,并且仅在流程开始时获取一次。
我正在考虑做这样的事情,但显然,这是行不通的。有人有主意吗?
Dictionary<int, DateTime> existingItems =
(from ObjType ot in TableObj
select (new KeyValuePair<int, DateTime>(ot.Key, ot.TimeStamp))
)
我最终想要的是一个字典,而不必从 TableObject 下载整个 ObjectType 对象。
我还考虑了以下代码,但我试图找到合适的方法:
List<int> keys = (from ObjType ot in TableObj orderby ot.Key select ot.Key).ToList<int>();
List<DateTime> values = (from ObjType ot in TableObj orderby ot.Key select ot.Value).ToList<int>();
Dictionary<int, DateTime> existingItems = new Dictionary<int, DateTime>(keys.Count);
for (int i = 0; i < keys.Count; i++)
{
existingItems.Add(keys[i], values[i]);
}
尝试使用the ToDictionary method像这样:
var dict = TableObj.Select( t => new { t.Key, t.TimeStamp } )
.ToDictionary( t => t.Key, t => t.TimeStamp );
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)