Eu tenho o seguinte ...
JArray clients = (JArray)clientsParsed["objects"];
foreach (JObject item in clients.Children())
{
// etc.. SQL params stuff...
command.Parameters["@MyParameter"].Value = JTokenToSql(item["thisParameter"]);
}
JTokenToSql
se parece com isso...
public static object JTokenToSql(JToken obj)
{
if (obj.Any())
return (object)obj;
else
return (object)DBNull.Value;
}
Eu tentei ((JObject)obj).Count
também .. Mas não parece estar funcionando.
ToSrting
oJToken
e verificarIsNullOrWhiteSpace
? (Depois de verificarJToken
se não é nulo, é claro){}
e[]
respectivamente.Você pode proceder da seguinte forma para verificar se um valor JToken é nulo
JToken token = jObject["key"]; if(token.Type == JTokenType.Null) { // Do your logic }
fonte
Também existe um tipo - JTokenType.Undefined.
Este cheque deve ser incluído na resposta de @Brian Rogers.
token.Type == JTokenType.Undefined
fonte
A partir do C # 7, você também pode usar isto:
if (clientsParsed["objects"] is JArray clients) { foreach (JObject item in clients.Children()) { if (item["thisParameter"] as JToken itemToken) { command.Parameters["@MyParameter"].Value = JTokenToSql(itemToken); } } }
O operador is verifica o tipo e se está correto o valor está dentro da variável do cliente.
fonte
Tente algo assim para converter JToken em 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 }
fonte