Convert Linq Query Result to Dictionary
我想使用linq to sql向数据库添加一些行,但我想在添加行之前进行"自定义检查",以确定是否必须添加、替换或忽略输入行。我希望尽可能减少客户端和DB服务器之间的流量,并尽量减少查询的数量。
为此,我希望获取验证所需的尽可能少的信息,并且仅在过程开始时获取一次。
我本来想做这样的事,但显然不行。有人有主意吗?
1 2 3 4 | Dictionary<int, DateTime> existingItems = (from ObjType ot in TableObj select (new KeyValuePair<int, DateTime>(ot.Key, ot.TimeStamp)) ) |
最后我想要的是一本字典,不需要从TableObject下载整个ObjectType对象。
我还考虑了以下代码,但我试图找到一个合适的方法:
1 2 3 4 5 6 7 | 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]); } |
尝试使用
1 | var dict = TableObj.ToDictionary( t => t.Key, t => t.TimeStamp ); |
看看你的例子,我认为这就是你想要的:
1 | var dict = TableObj.ToDictionary(t => t.Key, t=> t.TimeStamp); |
尝试以下操作
1 2 | Dictionary<int, DateTime> existingItems = (from ObjType ot in TableObj).ToDictionary(x => x.Key); |
或完全成熟的类型推断版本
1 | var existingItems = TableObj.ToDictionary(x => x.Key); |
使用命名空间
1 | using System.Collections.Specialized; |
以
1 |
使用
1 | OrderedDictionary dict = dc.TableName.ToDictionary(d => d.key, d => d.value); |
为了检索值,请使用命名空间
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | 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(); |