我想使用Linq to SQL向数据库添加一些行,但我想在添加行以前进行“自定义检查”,以了解是否必须添加,替换或忽略进行的行。 我想尽量下降客户端和数据库服务器之间的流量,并尽可能减小查询次数。 数据库
为此,我但愿获取验证所需的信息,而且只须要在流程开始时获取一次。 服务器
我在考虑作这样的事情,但很明显,它不起做用。 有人有想法吗? spa
Dictionary<int, DateTime> existingItems = (from ObjType ot in TableObj select (new KeyValuePair<int, DateTime>(ot.Key, ot.TimeStamp)) )
我最后想要的是一个Dictionary,而没必要从TableObject下载整个ObjectType对象。 code
我还考虑了如下代码,但我试图找到一个正确的方法: 对象
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]); }
使用命名空间 ci
using System.Collections.Specialized;
制做DataContext
类的实例 get
LinqToSqlDataContext dc = new LinqToSqlDataContext();
使用 it
OrderedDictionary dict = dc.TableName.ToDictionary(d => d.key, d => d.value);
为了检索值,使用命名空间 io
using System.Collections; ICollection keyCollections = dict.Keys; ICOllection valueCollections = dict.Values; String[] myKeys = new String[dict.Count]; String[] myValues = new String[dict.Count]; keyCollections.CopyTo(myKeys,0); valueCollections.CopyTo(myValues,0); for(int i=0; i<dict.Count; i++) { Console.WriteLine("Key: " + myKeys[i] + "Value: " + myValues[i]); } Console.ReadKey();
请尝试如下方法 List
Dictionary<int, DateTime> existingItems = (from ObjType ot in TableObj).ToDictionary(x => x.Key);
或彻底成熟的类型推断版本
var existingItems = TableObj.ToDictionary(x => x.Key);
看看你的例子,我认为这就是你想要的:
var dict = TableObj.ToDictionary(t => t.Key, t=> t.TimeStamp);
尝试使用ToDictionary
方法,以下所示:
var dict = TableObj.ToDictionary( t => t.Key, t => t.TimeStamp );