Condividi tramite


Funzione try_reflect

Si applica a: segno di spunta sì Databricks SQL segno di spunta sì Databricks Runtime 14.1 e versioni successive

Chiamare un metodo con reflection, restituendo NULL se il metodo restituisce un'eccezione.

Per restituire un errore, usare invece reflect.

Sintassi

try_reflect(class, method [, arg1] [, ...])

Argomenti

  • class: valore STRING letterale che specifica la classe java.
  • method: valore STRING letterale che specifica il metodo java.
  • argN: espressione con un tipo appropriato per il metodo selezionato.

Valori restituiti

Un oggetto STRING.

Esempi

> SELECT try_reflect('java.lang.Integer', 'valueOf', '1010', '2');
 c33fb387-8500-4bfa-81d2-6e0e3e930df2

> SELECT try_reflect('java.util.UUID', 'fromString', 'a5cf6c42-0c85-418f-af6c-3e4e5b1328f2');
 A5cf6c42-0c85-418f-af6c-3e4e5b1328f2

> SELECT try_reflect('java.util.UUID', 'IDoNotExist');
 c33fb387-8500-4bfa-81d2-6e0e3e930df2

> SELECT reflect('java.lang.Integer', 'divideUnsigned',10,0);
 Error

> SELECT try_reflect('java.lang.Integer', 'divideUnsigned',10,0);
 NULL