gpt4 book ai didi

c# - 具有动态类型的 Linq 查询

转载 作者:太空宇宙 更新时间:2023-11-03 20:14:03 25 4
gpt4 key购买 nike

我正在使用以下 linq 来解析我返回的数据集:

 row.Field<long?>("id").HasValue == false &&

我遇到的问题是,从Sql Server获取数据集时,字段需要用<int?>解析当它从 Oracle 获取时,需要解析为 <long?> .有没有办法创建一个变量,我可以将其传递给 .Field 方法以动态设置此数据类型?我想要这样的东西:

Type T = IsSqlServer ? typeof(int?) : typeof(long?);
....
row.Field<T>("id").HasValue == false &&

提前致谢!

最佳答案

您可以使用反射(不推荐)或只使用三元运算符:

!(IsSqlServer ? row.Field<int?>("id").HasValue : row.Field<long?>("id").HasValue)

关于c# - 具有动态类型的 Linq 查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18082194/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com