Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/linq/3.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
使用LINQ查询具有Lambda表达式的IDictionary_Linq_Linq To Entities - Fatal编程技术网

使用LINQ查询具有Lambda表达式的IDictionary

使用LINQ查询具有Lambda表达式的IDictionary,linq,linq-to-entities,Linq,Linq To Entities,为什么即使在调试时字典显示了正确的键/值对,它也不会返回正确的字符串 IDictionary<string, string> states = AFS.MvcApplication.UnitedStates.StateDictionary; string stateAbbrev = states.Where(x => x.Key == State).Select(x => x.Value).ToSt

为什么即使在调试时字典显示了正确的键/值对,它也不会返回正确的字符串

IDictionary<string, string> states = 
                   AFS.MvcApplication.UnitedStates.StateDictionary;

string stateAbbrev = 
               states.Where(x => x.Key == State).Select(x => x.Value).ToString();
IDictionary状态=
AFS.mvcapapplication.UnitedStates.StateDictionary;
字符串stateAbbrev=
states.Where(x=>x.Key==State).Select(x=>x.Value.ToString();

您希望使用
FirstOrDefault
而不是
ToString
,因为
Select
的结果是一个
IEnumerable
。这应该起作用:

string stateAbbrev = states.Where(x => x.Key == State).Select(x => x.Value).FirstOrDefault();
你应使用:

string stateAbbrev =  states[State];