Catégories :

Fonctions de chaîne et fonctions binaires (Encodage/Décodage)

TRY_HEX_DECODE_BINARY

Une version spéciale de HEX_DECODE_BINARY qui renvoie une valeur NULL si une erreur se produit pendant le décodage.

Syntaxe

TRY_HEX_DECODE_BINARY(<input>) 
Copy

Arguments

input

Une expression de chaîne contenant uniquement des chiffres hexadécimaux. En règle générale, cette chaîne d’entrée est générée en appelant la fonction HEX_ENCODE.

Renvoie

Une valeur BINARY pouvant, par exemple, être insérée dans une colonne de type BINARY.

Exemples

Ceci montre comment utiliser la fonction TRY_HEX_DECODE_BINARY (notez que la fonction est utilisée dans l’instruction INSERT pour décoder en un champ BINARY ; la fonction n’est pas utilisée dans l’instruction SELECT) :

Créez une table et des données :

CREATE TABLE hex (v VARCHAR, b BINARY); INSERT INTO hex (v, b) SELECT 'ABab', -- Convert string -> hex-encoded string -> binary. TRY_HEX_DECODE_BINARY(HEX_ENCODE('ABab')); 
Copy

Maintenant, exécutez une requête pour montrer que nous pouvons récupérer les données intactes :

SELECT v, b, -- Convert binary -> hex-encoded-string -> string. TRY_HEX_DECODE_STRING(TO_VARCHAR(b)) FROM hex; 
Copy

Sortie :

+------+----------+--------------------------------------+ | V | B | TRY_HEX_DECODE_STRING(TO_VARCHAR(B)) | |------+----------+--------------------------------------| | ABab | 41426162 | ABab | +------+----------+--------------------------------------+ 
Copy