Ada fungsi base-64 (seperti encode
) tapi tidak untuk base-36. Tapi Anda bisa menulis salah satu dari Anda sendiri atau gunakan yang ini
:
CREATE OR REPLACE FUNCTION base36_encode(IN digits bigint, IN min_width int = 0) RETURNS varchar AS $$
DECLARE
chars char[];
ret varchar;
val bigint;
BEGIN
chars := ARRAY['0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z'];
val := digits;
ret := '';
IF val < 0 THEN
val := val * -1;
END IF;
WHILE val != 0 LOOP
ret := chars[(val % 36)+1] || ret;
val := val / 36;
END LOOP;
IF min_width > 0 AND char_length(ret) < min_width THEN
ret := lpad(ret, min_width, '0');
END IF;
RETURN ret;
END;
$$ LANGUAGE plpgsql IMMUTABLE;
Saya pikir Anda harus bertanya pada diri sendiri apakah database adalah tempat yang tepat untuk menangani pemformatan data semacam ini, masalah presentasi seperti ini mungkin lebih baik ditangani lebih dekat ke tingkat tampilan akhir tumpukan Anda.