"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > Baseencoded 문자열에서 키-값 쌍을 구문 분석하는 방법#eg11

Baseencoded 문자열에서 키-값 쌍을 구문 분석하는 방법#eg11

2024-08-08에 게시됨
검색:373

다음과 같이 Base64로 인코딩된 문자열이 있습니다.

eyJhIjo2MywiYyI6Mjk4LCJuIjoxLCJzIjoxLCJlIjo0MCwicCI6NH0=

트랜스코딩된 JSON 문자열({"a":63,"c":298,"n":1,"s":1,"e":40,"p":4})을 구문 분석하려고 합니다. )를 테이블로 사용합니다. 다음은 원하는 결과입니다.

Image description
MySQL로 작성된 SQL:

SELECT

            JSON_EXTRACT(CONVERT(FROM_BASE64('eyJhIjo2MywiYyI6Mjk4LCJuIjoxLCJzIjoxLCJlIjo0MCwicCI6NH0=')

                        USING utf8),

            '$."a"') a,

            JSON_EXTRACT(CONVERT(FROM_BASE64('eyJhIjo2MywiYyI6Mjk4LCJuIjoxLCJzIjoxLCJlIjo0MCwicCI6NH0=')

                        USING utf8),

            '$."c"') c,

            JSON_EXTRACT(CONVERT(FROM_BASE64('eyJhIjo2MywiYyI6Mjk4LCJuIjoxLCJzIjoxLCJlIjo0MCwicCI6NH0=')

                        USING utf8),

            '$."n"') n,

            JSON_EXTRACT(CONVERT(FROM_BASE64('eyJhIjo2MywiYyI6Mjk4LCJuIjoxLCJzIjoxLCJlIjo0MCwicCI6NH0=')

                        USING utf8),

            '$."s"') s,

            JSON_EXTRACT(CONVERT(FROM_BASE64('eyJhIjo2MywiYyI6Mjk4LCJuIjoxLCJzIjoxLCJlIjo0MCwicCI6NH0=')

                        USING utf8),

            '$."e"') e,

            JSON_EXTRACT(CONVERT(FROM_BASE64('eyJhIjo2MywiYyI6Mjk4LCJuIjoxLCJzIjoxLCJlIjo0MCwicCI6NH0=')

                        USING utf8),

            '$."p"') p

어려운 점은 없습니다. Base64로 인코딩된 문자열을 JSON 문자열로 변환한 다음 K-V 쌍에 따라 JSON을 테이블로 구문 분석하기만 하면 됩니다. SQL 코딩은 특히 결과 테이블의 열 수를 알 수 없는 경우 복잡합니다.

 

오픈 소스 esProc SPL에서 코딩하기 쉽습니다:

매개변수 arg1의 값이 다음과 같다고 가정합니다.

eyJhIjo2MywiYyI6Mjk4LCJuIjoxLCJzIjoxLCJlIjo0MCwicCI6NH0=

Image description
SPL은 전문적인 구조화된 오픈 소스 데이터 계산 언어로서 JSON을 포함한 다양한 데이터 소스를 처리하는 데 편리합니다.

릴리스 선언문 이 기사는 https://dev.to/esproc_spl/how-to-parse-key-value-pairs-from-a-base64-encoded-stringeg11-a6e?1에서 복제됩니다. 침해 사항이 있는 경우, Study_golang에 문의하세요. @163.com 삭제
최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3