{"id":1585,"date":"2025-01-09T06:00:15","date_gmt":"2025-01-09T06:00:15","guid":{"rendered":"https:\/\/craftcookcode.com\/?p=1585"},"modified":"2025-01-09T23:57:17","modified_gmt":"2025-01-09T23:57:17","slug":"postgres-ebcdic-decoding-through-a-javascript-function","status":"publish","type":"post","link":"https:\/\/craftcookcode.com\/?p=1585","title":{"rendered":"Postgres: EBCDIC decoding through a JavaScript Function"},"content":{"rendered":"\n<h2 class=\"wp-block-heading\">EBCDIC?  Didn&#8217;t that die out with punch cards and the Dinosaurs?<\/h2>\n\n\n\n<p><a href=\"https:\/\/en.wikipedia.org\/wiki\/EBCDIC\" target=\"_blank\" rel=\"noopener\" title=\"\">EBCDIC<\/a> (Extended Binary Coded Decimal Interchange Code) is an eight-bit character encoding that was created by IBM in the &#8217;60s.  <\/p>\n\n\n\n<p>While the rest of the world went on with ASCII and UTF-8; we still find fields in our DB2 database encoded in EBCDIC 037 just to make our lives miserable.<\/p>\n\n\n\n<p>Qlik Replicate when replicating from these fields on its default settings; brings it across as a normal &#8220;string&#8221; and becomes quite unusable when loaded into a destination system.  <\/p>\n\n\n\n<h2 class=\"wp-block-heading\">Decoding EBCDIC in Postgres<\/h2>\n\n\n\n<p>To have the flexibility to decode particular fields in EBCDIC; we need to bring the fields across as BYTES instead of that QR suggests.  This can be done in the Table Settings for the table in question:<\/p>\n\n\n\n<figure class=\"wp-block-image size-full\"><img fetchpriority=\"high\" decoding=\"async\" width=\"2787\" height=\"1524\" src=\"https:\/\/craftcookcode.com\/wp-content\/uploads\/2025\/01\/code_ebcdic_function_01.png\" alt=\"\" class=\"wp-image-1587\" srcset=\"https:\/\/craftcookcode.com\/wp-content\/uploads\/2025\/01\/code_ebcdic_function_01.png 2787w, https:\/\/craftcookcode.com\/wp-content\/uploads\/2025\/01\/code_ebcdic_function_01-300x164.png 300w, https:\/\/craftcookcode.com\/wp-content\/uploads\/2025\/01\/code_ebcdic_function_01-1024x560.png 1024w, https:\/\/craftcookcode.com\/wp-content\/uploads\/2025\/01\/code_ebcdic_function_01-768x420.png 768w, https:\/\/craftcookcode.com\/wp-content\/uploads\/2025\/01\/code_ebcdic_function_01-1536x840.png 1536w, https:\/\/craftcookcode.com\/wp-content\/uploads\/2025\/01\/code_ebcdic_function_01-2048x1120.png 2048w\" sizes=\"(max-width: 2787px) 100vw, 2787px\" \/><\/figure>\n\n\n\n<p>On the destination Postgres database; load the table into a bytea field.<\/p>\n\n\n\n<p>Now with a udf function in Postgres; we can decode the EBCDIC bytes fields into something readable:<\/p>\n\n\n<div class=\"wp-block-syntaxhighlighter-code \"><pre class=\"brush: jscript; title: ; notranslate\" title=\"\">\nCREATE OR REPLACE FUNCTION public.fn_convert_bytes2_037(\n    in_bytes bytea)\n    RETURNS character varying\n    LANGUAGE &#039;plv8&#039;\n    COST 100\n    VOLATILE PARALLEL UNSAFE\nAS $BODY$\n    const hex_037 = new Map(&#x5B;\n        &#x5B;&quot;40&quot;, &quot; &quot;,],\n        &#x5B;&quot;41&quot;, &quot; &quot;,],\n        &#x5B;&quot;42&quot;, &quot;\u00e2&quot;,],\n        &#x5B;&quot;43&quot;, &quot;\u00e4&quot;,],\n        &#x5B;&quot;44&quot;, &quot;\u00e0&quot;,],\n        &#x5B;&quot;45&quot;, &quot;\u00e1&quot;,],\n        &#x5B;&quot;46&quot;, &quot;\u00e3&quot;,],\n        &#x5B;&quot;47&quot;, &quot;\u00e5&quot;,],\n        &#x5B;&quot;48&quot;, &quot;\u00e7&quot;,],\n        &#x5B;&quot;49&quot;, &quot;\u00f1&quot;,],\n        &#x5B;&quot;4a&quot;, &quot;\u00a2&quot;,],\n        &#x5B;&quot;4b&quot;, &quot;.&quot;,],\n        &#x5B;&quot;4c&quot;, &quot;&lt;&quot;,],\n        &#x5B;&quot;4d&quot;, &quot;(&quot;,],\n        &#x5B;&quot;4e&quot;, &quot;+&quot;,],\n        &#x5B;&quot;4f&quot;, &quot;|&quot;,],\n        &#x5B;&quot;50&quot;, &quot;&amp;&quot;,],\n        &#x5B;&quot;51&quot;, &quot;\u00e9&quot;,],\n        &#x5B;&quot;52&quot;, &quot;\u00ea&quot;,],\n        &#x5B;&quot;53&quot;, &quot;\u00eb&quot;,],\n        &#x5B;&quot;54&quot;, &quot;\u00e8&quot;,],\n        &#x5B;&quot;55&quot;, &quot;\u00ed&quot;,],\n        &#x5B;&quot;56&quot;, &quot;\u00ee&quot;,],\n        &#x5B;&quot;57&quot;, &quot;\u00ef&quot;,],\n        &#x5B;&quot;58&quot;, &quot;\u00ec&quot;,],\n        &#x5B;&quot;59&quot;, &quot;\u00df&quot;,],\n        &#x5B;&quot;5a&quot;, &quot;!&quot;,],\n        &#x5B;&quot;5b&quot;, &quot;$&quot;,],\n        &#x5B;&quot;5c&quot;, &quot;*&quot;,],\n        &#x5B;&quot;5d&quot;, &quot;)&quot;,],\n        &#x5B;&quot;5e&quot;, &quot;;&quot;,],\n        &#x5B;&quot;5f&quot;, &quot;\u00ac&quot;,],\n        &#x5B;&quot;60&quot;, &quot;-&quot;,],\n        &#x5B;&quot;61&quot;, &quot;\/&quot;,],\n        &#x5B;&quot;62&quot;, &quot;\u00c2&quot;,],\n        &#x5B;&quot;63&quot;, &quot;\u00c4&quot;,],\n        &#x5B;&quot;64&quot;, &quot;\u00c0&quot;,],\n        &#x5B;&quot;65&quot;, &quot;\u00c1&quot;,],\n        &#x5B;&quot;66&quot;, &quot;\u00c3&quot;,],\n        &#x5B;&quot;67&quot;, &quot;\u00c5&quot;,],\n        &#x5B;&quot;68&quot;, &quot;\u00c7&quot;,],\n        &#x5B;&quot;69&quot;, &quot;\u00d1&quot;,],\n        &#x5B;&quot;6a&quot;, &quot;\u00a6&quot;,],\n        &#x5B;&quot;6b&quot;, &quot;,&quot;,],\n        &#x5B;&quot;6c&quot;, &quot;%&quot;,],\n        &#x5B;&quot;6d&quot;, &quot;_&quot;,],\n        &#x5B;&quot;6e&quot;, &quot;&gt;&quot;,],\n        &#x5B;&quot;6f&quot;, &quot;?&quot;,],\n        &#x5B;&quot;70&quot;, &quot;\u00f8&quot;,],\n        &#x5B;&quot;71&quot;, &quot;\u00c9&quot;,],\n        &#x5B;&quot;72&quot;, &quot;\u00ca&quot;,],\n        &#x5B;&quot;73&quot;, &quot;\u00cb&quot;,],\n        &#x5B;&quot;74&quot;, &quot;\u00c8&quot;,],\n        &#x5B;&quot;75&quot;, &quot;\u00cd&quot;,],\n        &#x5B;&quot;76&quot;, &quot;\u00ce&quot;,],\n        &#x5B;&quot;77&quot;, &quot;\u00cf&quot;,],\n        &#x5B;&quot;78&quot;, &quot;\u00cc&quot;,],\n        &#x5B;&quot;79&quot;, &quot;`&quot;,],\n        &#x5B;&quot;7a&quot;, &quot;:&quot;,],\n        &#x5B;&quot;7b&quot;, &quot;#&quot;,],\n        &#x5B;&quot;7c&quot;, &quot;@&quot;,],\n        &#x5B;&quot;7d&quot;, &quot;&#039;&quot;,],\n        &#x5B;&quot;7e&quot;, &quot;=&quot;,],\n        &#x5B;&quot;7f&quot;, &quot;,&quot;],\n        &#x5B;&quot;80&quot;, &quot;\u00d8&quot;,],\n        &#x5B;&quot;81&quot;, &quot;a&quot;,],\n        &#x5B;&quot;82&quot;, &quot;b&quot;,],\n        &#x5B;&quot;83&quot;, &quot;c&quot;,],\n        &#x5B;&quot;84&quot;, &quot;d&quot;,],\n        &#x5B;&quot;85&quot;, &quot;e&quot;,],\n        &#x5B;&quot;86&quot;, &quot;f&quot;,],\n        &#x5B;&quot;87&quot;, &quot;g&quot;,],\n        &#x5B;&quot;88&quot;, &quot;h&quot;,],\n        &#x5B;&quot;89&quot;, &quot;i&quot;,],\n        &#x5B;&quot;8a&quot;, &quot;\u00ab&quot;,],\n        &#x5B;&quot;8b&quot;, &quot;\u00bb&quot;,],\n        &#x5B;&quot;8c&quot;, &quot;\u00f0&quot;,],\n        &#x5B;&quot;8d&quot;, &quot;\u00fd&quot;,],\n        &#x5B;&quot;8e&quot;, &quot;\u00fe&quot;,],\n        &#x5B;&quot;8f&quot;, &quot;\u00b1&quot;,],\n        &#x5B;&quot;90&quot;, &quot;\u00b0&quot;,],\n        &#x5B;&quot;91&quot;, &quot;j&quot;,],\n        &#x5B;&quot;92&quot;, &quot;k&quot;,],\n        &#x5B;&quot;93&quot;, &quot;l&quot;,],\n        &#x5B;&quot;94&quot;, &quot;m&quot;,],\n        &#x5B;&quot;95&quot;, &quot;n&quot;,],\n        &#x5B;&quot;96&quot;, &quot;o&quot;,],\n        &#x5B;&quot;97&quot;, &quot;p&quot;,],\n        &#x5B;&quot;98&quot;, &quot;q&quot;,],\n        &#x5B;&quot;99&quot;, &quot;r&quot;,],\n        &#x5B;&quot;9a&quot;, &quot;\u00aa&quot;,],\n        &#x5B;&quot;9b&quot;, &quot;\u00ba&quot;,],\n        &#x5B;&quot;9c&quot;, &quot;\u00e6&quot;,],\n        &#x5B;&quot;9d&quot;, &quot;\u00b8&quot;,],\n        &#x5B;&quot;9e&quot;, &quot;\u00c6&quot;,],\n        &#x5B;&quot;9f&quot;, &quot;\u00a4&quot;,],\n        &#x5B;&quot;a0&quot;, &quot;\u00b5&quot;,],\n        &#x5B;&quot;a1&quot;, &quot;~&quot;,],\n        &#x5B;&quot;a2&quot;, &quot;s&quot;,],\n        &#x5B;&quot;a3&quot;, &quot;t&quot;,],\n        &#x5B;&quot;a4&quot;, &quot;u&quot;,],\n        &#x5B;&quot;a5&quot;, &quot;v&quot;,],\n        &#x5B;&quot;a6&quot;, &quot;w&quot;,],\n        &#x5B;&quot;a7&quot;, &quot;x&quot;,],\n        &#x5B;&quot;a8&quot;, &quot;y&quot;,],\n        &#x5B;&quot;a9&quot;, &quot;z&quot;,],\n        &#x5B;&quot;aa&quot;, &quot;\u00a1&quot;,],\n        &#x5B;&quot;ab&quot;, &quot;\u00bf&quot;,],\n        &#x5B;&quot;ac&quot;, &quot;\u00d0&quot;,],\n        &#x5B;&quot;ad&quot;, &quot;\u00dd&quot;,],\n        &#x5B;&quot;ae&quot;, &quot;\u00de&quot;,],\n        &#x5B;&quot;af&quot;, &quot;\u00ae&quot;,],\n        &#x5B;&quot;b0&quot;, &quot;^&quot;,],\n        &#x5B;&quot;b1&quot;, &quot;\u00a3&quot;,],\n        &#x5B;&quot;b2&quot;, &quot;\u00a5&quot;,],\n        &#x5B;&quot;b3&quot;, &quot;\u00b7&quot;,],\n        &#x5B;&quot;b4&quot;, &quot;\u00a9&quot;,],\n        &#x5B;&quot;b5&quot;, &quot;\u00a7&quot;,],\n        &#x5B;&quot;b6&quot;, &quot;\u00b6&quot;,],\n        &#x5B;&quot;b7&quot;, &quot;\u00bc&quot;,],\n        &#x5B;&quot;b8&quot;, &quot;\u00bd&quot;,],\n        &#x5B;&quot;b9&quot;, &quot;\u00be&quot;,],\n        &#x5B;&quot;ba&quot;, &quot;&#x5B;&quot;,],\n        &#x5B;&quot;bb&quot;, &quot;]&quot;,],\n        &#x5B;&quot;bc&quot;, &quot;\u00af&quot;,],\n        &#x5B;&quot;bd&quot;, &quot;\u00a8&quot;,],\n        &#x5B;&quot;be&quot;, &quot;\u00b4&quot;,],\n        &#x5B;&quot;bf&quot;, &quot;\u00d7&quot;,],\n        &#x5B;&quot;c0&quot;, &quot;{&quot;,],\n        &#x5B;&quot;c1&quot;, &quot;A&quot;,],\n        &#x5B;&quot;c2&quot;, &quot;B&quot;,],\n        &#x5B;&quot;c3&quot;, &quot;C&quot;,],\n        &#x5B;&quot;c4&quot;, &quot;D&quot;,],\n        &#x5B;&quot;c5&quot;, &quot;E&quot;,],\n        &#x5B;&quot;c6&quot;, &quot;F&quot;,],\n        &#x5B;&quot;c7&quot;, &quot;G&quot;,],\n        &#x5B;&quot;c8&quot;, &quot;H&quot;,],\n        &#x5B;&quot;c9&quot;, &quot;I&quot;,],\n        &#x5B;&quot;ca&quot;, &quot;\u00ad&quot;,],\n        &#x5B;&quot;cb&quot;, &quot;\u00f4&quot;,],\n        &#x5B;&quot;cc&quot;, &quot;\u00f6&quot;,],\n        &#x5B;&quot;cd&quot;, &quot;\u00f2&quot;,],\n        &#x5B;&quot;ce&quot;, &quot;\u00f3&quot;,],\n        &#x5B;&quot;cf&quot;, &quot;\u00f5&quot;,],\n        &#x5B;&quot;d0&quot;, &quot;}&quot;,],\n        &#x5B;&quot;d1&quot;, &quot;J&quot;,],\n        &#x5B;&quot;d2&quot;, &quot;K&quot;,],\n        &#x5B;&quot;d3&quot;, &quot;L&quot;,],\n        &#x5B;&quot;d4&quot;, &quot;M&quot;,],\n        &#x5B;&quot;d5&quot;, &quot;N&quot;,],\n        &#x5B;&quot;d6&quot;, &quot;O&quot;,],\n        &#x5B;&quot;d7&quot;, &quot;P&quot;,],\n        &#x5B;&quot;d8&quot;, &quot;Q&quot;,],\n        &#x5B;&quot;d9&quot;, &quot;R&quot;,],\n        &#x5B;&quot;da&quot;, &quot;\u00b9&quot;,],\n        &#x5B;&quot;db&quot;, &quot;\u00fb&quot;,],\n        &#x5B;&quot;dc&quot;, &quot;\u00fc&quot;,],\n        &#x5B;&quot;dd&quot;, &quot;\u00f9&quot;,],\n        &#x5B;&quot;de&quot;, &quot;\u00fa&quot;,],\n        &#x5B;&quot;df&quot;, &quot;\u00ff&quot;,],\n        &#x5B;&quot;e0&quot;, &quot;\\\\&quot;,],\n        &#x5B;&quot;e1&quot;, &quot;\u00f7&quot;,],\n        &#x5B;&quot;e2&quot;, &quot;S&quot;,],\n        &#x5B;&quot;e3&quot;, &quot;T&quot;,],\n        &#x5B;&quot;e4&quot;, &quot;U&quot;,],\n        &#x5B;&quot;e5&quot;, &quot;V&quot;,],\n        &#x5B;&quot;e6&quot;, &quot;W&quot;,],\n        &#x5B;&quot;e7&quot;, &quot;X&quot;,],\n        &#x5B;&quot;e8&quot;, &quot;Y&quot;,],\n        &#x5B;&quot;e9&quot;, &quot;Z&quot;,],\n        &#x5B;&quot;ea&quot;, &quot;\u00b2&quot;,],\n        &#x5B;&quot;eb&quot;, &quot;\u00d4&quot;,],\n        &#x5B;&quot;ec&quot;, &quot;\u00d6&quot;,],\n        &#x5B;&quot;ed&quot;, &quot;\u00d2&quot;,],\n        &#x5B;&quot;ee&quot;, &quot;\u00d3&quot;,],\n        &#x5B;&quot;ef&quot;, &quot;\u00d5&quot;,],\n        &#x5B;&quot;f0&quot;, &quot;0&quot;,],\n        &#x5B;&quot;f1&quot;, &quot;1&quot;,],\n        &#x5B;&quot;f2&quot;, &quot;2&quot;,],\n        &#x5B;&quot;f3&quot;, &quot;3&quot;,],\n        &#x5B;&quot;f4&quot;, &quot;4&quot;,],\n        &#x5B;&quot;f5&quot;, &quot;5&quot;,],\n        &#x5B;&quot;f6&quot;, &quot;6&quot;,],\n        &#x5B;&quot;f7&quot;, &quot;7&quot;,],\n        &#x5B;&quot;f8&quot;, &quot;8&quot;,],\n        &#x5B;&quot;f9&quot;, &quot;9&quot;,],\n        &#x5B;&quot;fa&quot;, &quot;\u00b3&quot;,],\n        &#x5B;&quot;fb&quot;, &quot;\u00db&quot;,],\n        &#x5B;&quot;fc&quot;, &quot;\u00dc&quot;,],\n        &#x5B;&quot;fd&quot;, &quot;\u00d9&quot;,],\n        &#x5B;&quot;fe&quot;, &quot;\u00da&quot;]\n    ]);\n \n    let in_varchar = &quot;&quot;;\n    let build_string = &quot;&quot;;\n     \n    for (var loop_bytes = 0; loop_bytes &lt; in_bytes.length; loop_bytes++)\n    {\n        \/* Converts a byte character to a hex representation*\/\n        let focus_char = (&#039;0&#039; + (in_bytes&#x5B;loop_bytes] &amp; 0xFF).toString(16)).slice(-2); \n        let return_value = hex_037.get(focus_char.toLowerCase());\n \n        \/* If no mapping found - replace the character with a space *\/\n        if(return_value === undefined)\n        {\n            return_value = &quot; &quot;;\n        }\n \n        build_string = build_string.concat(return_value)\n    }\n \n    return build_string\n$BODY$;\n<\/pre><\/div>\n\n\n<p>The function can now be used in SQL:<\/p>\n\n\n<div class=\"wp-block-syntaxhighlighter-code \"><pre class=\"brush: sql; title: ; notranslate\" title=\"\">\nSELECT public.fn_convert_bytes2_037(my_EBCDIC_byte_column)\nFROM public.foo;\n<\/pre><\/div>\n\n\n<h2 class=\"wp-block-heading\">Reference<\/h2>\n\n\n\n<p>JavaScript bytes to HEX string function: Code Shock &#8211; <a href=\"https:\/\/codeshock.dev\/news\/how-to-convert-between-hexadecimal-strings-and-byte-arrays-in-javascript\/\" target=\"_blank\" rel=\"noopener\" title=\"\">How to Convert Between Hexadecimal Strings and Byte Arrays in JavaScript<\/a><\/p>\n\n\n\n<p><\/p>\n","protected":false},"excerpt":{"rendered":"<p>EBCDIC? Didn&#8217;t that die out with punch cards and the Dinosaurs? EBCDIC (Extended Binary Coded Decimal Interchange Code) is an eight-bit character encoding that was created&#46;&#46;&#46;<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"om_disable_all_campaigns":false,"_monsterinsights_skip_tracking":false,"_monsterinsights_sitenote_active":false,"_monsterinsights_sitenote_note":"","_monsterinsights_sitenote_category":0,"footnotes":""},"categories":[64,16],"tags":[79,78,75,56,36],"class_list":["post-1585","post","type-post","status-publish","format-standard","hentry","category-postgres","category-qlik-replicate","tag-79","tag-ebcdic","tag-javascript","tag-postgres","tag-qlikreplicate"],"aioseo_notices":[],"_links":{"self":[{"href":"https:\/\/craftcookcode.com\/index.php?rest_route=\/wp\/v2\/posts\/1585","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/craftcookcode.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/craftcookcode.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/craftcookcode.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/craftcookcode.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=1585"}],"version-history":[{"count":2,"href":"https:\/\/craftcookcode.com\/index.php?rest_route=\/wp\/v2\/posts\/1585\/revisions"}],"predecessor-version":[{"id":1590,"href":"https:\/\/craftcookcode.com\/index.php?rest_route=\/wp\/v2\/posts\/1585\/revisions\/1590"}],"wp:attachment":[{"href":"https:\/\/craftcookcode.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=1585"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/craftcookcode.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=1585"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/craftcookcode.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=1585"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}