首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >System.Linq.Dynamic.Core不能将“object”类型强制转换为“Tuple<T1,T2,T3>”

System.Linq.Dynamic.Core不能将“object”类型强制转换为“Tuple<T1,T2,T3>”
EN

Stack Overflow用户
提问于 2021-03-21 14:41:16
回答 1查看 23关注 0票数 0

我正在使用System.Linq.Dynamic.Core并尝试使用一个模型运行一个动态查询,如下所示:

代码语言:javascript
复制
public class Index
{
    public long Position { get; set; }

    public object[] Values { get; set; }
}

下面是一个数据示例:

代码语言:javascript
复制
var indexes = new Dictionary<long, Index>();
indexes.Add(1, new Index { Position = 1000, Values = new object[3] { "Welly", "Chandra", Tuple.Create<int, int>(1, 2) } });
indexes.Add(2, new Index { Position = 1001, Values = new object[3] { "Darma", "Angelo", Tuple.Create<int, int>(3, 4) } });
indexes.Add(3, new Index { Position = 1002, Values = new object[3] { "Abby", "Yeremia", Tuple.Create<int, int>(5, 6)} });
indexes.Add(4, new Index { Position = 1003, Values = new object[3] { "Yonathan", "Gunawan", Tuple.Create<int, int>(7, 8)} });
indexes.Add(5, new Index { Position = 1004, Values = new object[3] { "Aldy", "Santoso", Tuple.Create<int, int>(11, 12)} });
var queryable = indexes.Values.AsQueryable();
var result = queryable.Where("Values[1].Equals(\"Yeremia\") || ((Tuple<int, int>) Values[2]).Item2.Equals(8)").ToList();

但是它总是抛出一个异常:

代码语言:javascript
复制
Exception: No property or field 'Tuple' exists in ...

在这里查询时不能使用type-casting吗?

EN

回答 1

Stack Overflow用户

发布于 2021-03-21 14:50:58

我不明白为什么你要在linq where子句中写字符串。

下面是我那端完整的工作代码。

代码语言:javascript
复制
var indexes = new Dictionary<long, Index>();
            indexes.Add(1, new Index { Position = 1000, Values = new object[3] { "Welly", "Chandra", Tuple.Create<int, int>(1, 2) } });
            indexes.Add(2, new Index { Position = 1001, Values = new object[3] { "Darma", "Angelo", Tuple.Create<int, int>(3, 4) } });
            indexes.Add(3, new Index { Position = 1002, Values = new object[3] { "Abby", "Yeremia", Tuple.Create<int, int>(5, 6) } });
            indexes.Add(4, new Index { Position = 1003, Values = new object[3] { "Yonathan", "Gunawan", Tuple.Create<int, int>(7, 8) } });
            indexes.Add(5, new Index { Position = 1004, Values = new object[3] { "Aldy", "Santoso", Tuple.Create<int, int>(11, 12) } });
            var queryable = indexes.Values.AsQueryable();
            var result = queryable.Where(cc=>cc.Values[1].Equals("Yeremia") || ((Tuple<int, int>) cc.Values[2]).Item2.Equals(8)).ToList();

更新:这对我很有效。不需要类型转换。

代码语言:javascript
复制
 var indexes = new Dictionary<long, Index>();
            indexes.Add(1, new Index { Position = 1000, Values = new object[3] { "Welly", "Chandra", Tuple.Create<int, int>(1, 2) } });
            indexes.Add(2, new Index { Position = 1001, Values = new object[3] { "Darma", "Angelo", Tuple.Create<int, int>(3, 4) } });
            indexes.Add(3, new Index { Position = 1002, Values = new object[3] { "Abby", "Yeremia", Tuple.Create<int, int>(5, 6) } });
            indexes.Add(4, new Index { Position = 1003, Values = new object[3] { "Yonathan", "Gunawan", Tuple.Create<int, int>(7, 8) } });
            indexes.Add(5, new Index { Position = 1004, Values = new object[3] { "Aldy", "Santoso", Tuple.Create<int, int>(11, 12) } });
            var queryable = indexes.Values.AsQueryable();
            var result = queryable.Where("Values[1].Equals(\"Yeremia\") || Values[2].Item2.Equals(8)").ToList();
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/66729536

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档