다음과 같이 Base64로 인코딩된 문자열이 있습니다.
eyJhIjo2MywiYyI6Mjk4LCJuIjoxLCJzIjoxLCJlIjo0MCwicCI6NH0=
트랜스코딩된 JSON 문자열({"a":63,"c":298,"n":1,"s":1,"e":40,"p":4})을 구문 분석하려고 합니다. )를 테이블로 사용합니다. 원하는 결과는 다음과 같습니다.
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=
SPL은 전문적인 구조화된 오픈 소스 데이터 계산 언어로서 JSON을 포함한 다양한 데이터 소스를 처리하는 데 편리합니다.
위 내용은 Baseencoded 문자열에서 키-값 쌍을 구문 분석하는 방법#eg11의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!