Mam następujące ...
JArray clients = (JArray)clientsParsed["objects"];
foreach (JObject item in clients.Children())
{
// etc.. SQL params stuff...
command.Parameters["@MyParameter"].Value = JTokenToSql(item["thisParameter"]);
}
JTokenToSql
wygląda tak...
public static object JTokenToSql(JToken obj)
{
if (obj.Any())
return (object)obj;
else
return (object)DBNull.Value;
}
Próbowałem ((JObject)obj).Count
też… Ale nie wydaje się działać.
ToSrting
JToken
IsNullOrWhiteSpace
JToken
{}
i[]
odpowiednio.Aby sprawdzić, czy wartość JToken jest zerowa, możesz wykonać następujące czynności
JToken token = jObject["key"]; if(token.Type == JTokenType.Null) { // Do your logic }
źródło
Istnieje również typ - JTokenType.Undefined.
To sprawdzenie musi być zawarte w odpowiedzi @Brian Rogers.
token.Type == JTokenType.Undefined
źródło
Od C # 7 możesz również użyć tego:
if (clientsParsed["objects"] is JArray clients) { foreach (JObject item in clients.Children()) { if (item["thisParameter"] as JToken itemToken) { command.Parameters["@MyParameter"].Value = JTokenToSql(itemToken); } } }
Operator is sprawdza typ i jeśli go poprawia, wartość znajduje się wewnątrz zmiennej klienta.
źródło
Spróbuj czegoś takiego, aby przekonwertować JToken na JArray:
static public JArray convertToJArray(JToken obj) { // if ((obj).Type == JTokenType.Null) --> You can check if it's null here if ((obj).Type == JTokenType.Array) return (JArray)(obj); else return new JArray(); // this will return an empty JArray }
źródło