Linq 检查空值并按顺序替换空值
本文关键字:空值 顺序 替换 检查 Linq | 更新日期: 2023-09-27 18:33:41
我有一个linq查询,有时字符串字段,产品名称,可能是空的,空的。这是表中的新字段,如果尚未输入数据,则在运行查询时出现错误。 我需要做的是检查空值,如果空,则用下拉列表中的文本值替换空/空值。我已经尝试了几种方法,但无法使其正常工作。
public IQueryable<Product> BindProduct([Control("ddProductName")] int? ProductNameId)
{
var prod = from c in _DbContext.Products
where c.ProductNameId == ProductNameId
orderby string.IsNullOrEmpty(c.ProductName) ? ddProductName.SelectedItem.Text : c.ProductName,
c.ItemNumber
select c;
return prod;
}
更改为:
public IQueryable<Product> BindProduct([Control("ddProductName")] int? ProductNameId)
{
var prodName = ddProductName.SelectedItem.Text;
var prod = from c in _DbContext.Products
where c.ProductNameId == ProductNameId
let sortName = c.Name ?? prodName
orderby sortName, c.ItemNumber
select new { c, sortName };
return prod;
}
更新:我想我不清楚。 我需要做的是检查空值,如果空,则用下拉列表中的文本值替换空/空值。
"Let"关键字应该可以解决问题。
下面是一个 LINQPad 示例:
var products = Enumerable.Range(0, 100).Select(q => new {ProductNameId = 1, ProductName = (q % 15 == 0 ? null : (q % 3 == 0 ? "Fizz" : (q % 5 == 0 ? "Buzz": q.ToString()))), ItemNumber = q});
var ddProductName_SelectedItem_Text = "FizzBuzz";
var ProductNameId = 1;
var prod = from c in products
where c.ProductNameId == ProductNameId
let sortName = c.ProductName ?? ddProductName_SelectedItem_Text
orderby sortName, c.ItemNumber
select c;
return prod; //prod.Dump(); //for linqpad debugging
答案来自我的同行布拉德。 对于想知道如何使用 linq 替换空/空值的其他任何人,请参阅下文。
public IQueryable<Product> BindProduct([Control("ddProductName")] int? ProductNameId)
{
var prodName = ddProductName.SelectedItem.Text;
var prod = _DbContext.Products.Where(c => c.ProductNameId == ProductNameId).ToList().Select
(p =>
{
p.Name = string.IsNullOrEmpty(p.Name) ? prodName : p.Name;
return p;
}).OrderBy(p => p.Name).ThenBy(p => p.ItemNumber).AsQueryable();
return prod;
}
在查询中调用 orderby 时,LINQ to SQL 将尝试将其解析为 SQL 中的 order by 语句。由于 SQL 没有条件顺序按语句的方法,因此该方法将无法从 LINQ 进行编译。
你想要的可以实现,但它需要排序设置的客户端而不是服务器端。我的建议是在没有排序依据的情况下运行查询,并在您需要排序时,首先将集合转换为 IEnumerable 集合。这会将 IQueryable 的结果提取到内存中,您将能够对对象集合运行 orderby。
基本流程如下所示:可查询。AsEnumerable((。OrderBy((
这里最重要的一点是要记住,LINQ 将尝试在您请求对集合进行枚举时将 IQueryable 转换为 SQL 查询。这里有一个很好的高级解释:http://blog.worldmaker.net/2013/mar/11/mini-lecture-linq-visualization/。