1

使用 SqlKata 查询生成器,我想根据我拥有的值构建一个更新查询。鉴于此代码:

   var query = new Query("Users");

   var user = new User{Age = 28, Name = "John"};


   query.When(user.Age != null, q => q.AsUpdate(new {Age = user.Age}))
       .When(user.Name != null, q => q.AsUpdate(new {Name = user.Name}));

生成的sql只有最后一个truthy子句。

4

1 回答 1

1

这是预期的,您的代码类似于以下内容

if(age != null)
{
    query.AsUpdate(new {Age = age})   
}

if(name != null)
{
    query.AsUpdate(new {Name = name})   
}

在这种情况下,最后一个真实的陈述总是会被评估。

如果您想使用这些.When方法,至少您必须使用第二个参数WhenNot来评估else零件。

var query = new Query("Users").When(age != null, 
    q => q.AsUpdate(new {Age = age}),
    q => q.When(name != null,  q2 => q2.AsUpdate(new {Name = name}))
);

在此处的操场上查看此示例:WhenNot 示例

但为了更灵活的方式,我建议使用字典对象并过滤掉可为空的值。

类似于(链接)的东西

using System.Collections.Generic;
using System.Linq;

var values = new Dictionary<string, object> {
    {"Age", null},
    {"Name", "ahmad"}
}.Where(x => x.Value != null).ToDictionary(x => x.Key, x => x.Value);

var query = new Query("Users").AsInsert(values);
于 2020-08-19T07:48:00.700 回答