c# - 检查 JObject 中的空 JToken 或空 JToken

标签 c# sql json.net

我有以下...

JArray clients = (JArray)clientsParsed["objects"];

foreach (JObject item in clients.Children())
{
    // etc.. SQL params stuff...
    command.Parameters["@MyParameter"].Value = JTokenToSql(item["thisParameter"]);
}

JTokenToSql 看起来像这样...

public static object JTokenToSql(JToken obj)
{
    if (obj.Any())
        return (object)obj;
    else
        return (object)DBNull.Value;
}

我也尝试过 ((JObject)obj).Count.. 但似乎没有用。

最佳答案

要检查 JObject 上是否存在某个属性,您可以使用方括号语法并查看结果是否为 null。如果该属性存在,将始终返回一个 JToken(即使它在 JSON 中的值为 null)。

JToken token = jObject["param"];
if (token != null)
{
    // the "param" property exists
}

如果你手头有一个JToken,你想看看它是否是非空的,那么,这取决于它是什么类型的JToken以及你如何定义“空”。我通常使用这样的扩展方法:

public static class JsonExtensions
{
    public static bool IsNullOrEmpty(this JToken token)
    {
        return (token == null) ||
               (token.Type == JTokenType.Array && !token.HasValues) ||
               (token.Type == JTokenType.Object && !token.HasValues) ||
               (token.Type == JTokenType.String && token.ToString() == String.Empty) ||
               (token.Type == JTokenType.Null);
    }
}

关于c# - 检查 JObject 中的空 JToken 或空 JToken,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24066400/

相关文章:

c# - .NET Google Calendar API 按日期排序事件

c# - WPF 绑定(bind)到自定义 DependencyProperty - IsChecked 有时是相反的属性值

sql - 为什么 Select Count(*) 比 Hive 中的 Select * 慢

sql - 重新编号文本列中的引用变量

c# - 通过自定义属性 (json.net) 从序列化中排除属性

json - NewtonSoft JsonConvert - 反序列化一个看起来像 { “@nil” : “true” } 的 JSON 对象

json - 如何限制 NewtonSoft.JSON 序列化一个接口(interface)?

c# - 如何在 C# 中将 CSHTML 读取为 XML 文件

sql - 如何连接多行的字符串?

c# - 如何在 WinForms 应用程序中处理表单?