Detailed example of MySQL (5.6 and below) parsing JSON

Detailed example of MySQL (5.6 and below) parsing JSON

MySQL (5.6 and below) parses json

#json parsing function DELIMITER $$
DROP FUNCTION IF EXISTS `json_extract_c`$$
CREATE FUNCTION `json_extract_c`(
details TEXT,
required_field VARCHAR (255)
) RETURNS TEXT CHARSET latin1
BEGIN
SET details = SUBSTRING_INDEX(details, "{", -1);
SET details = SUBSTRING_INDEX(details, "}", 1);
RETURN TRIM(
  BOTH '"' FROM SUBSTRING_INDEX(
    SUBSTRING_INDEX(
      SUBSTRING_INDEX(
        details,
        CONCAT(
'"',
          SUBSTRING_INDEX(required_field,'$.', -1),
'":'
        ),
-1
      ),
',"',
1
    ),
':',
-1
  )
) ;
END$$
DELIMITER ;
example:
select json_extract_c(json, "$.totalDays"), json from item limit 100;

Self-Test

CREATE TABLE `json_test` (
 `id` int(11) DEFAULT NULL,
 `person_desc` text COLLATE utf8mb4_unicode_ci
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
insert INTO json_test values(2,'{"firstName":"Sergei","lastName":"Rachmaninoff","instrument":"piano"}');
SELECT id,json_extract_c(person_desc,'$.lastName') as "keys" FROM json_test;

Improved: if the key is not found, return ''. Previously, if the key is not found, the first value is found.

CREATE DEFINER=`zhangfen`@`%` FUNCTION `json_extract_c`(
details TEXT,
required_field VARCHAR (255)
) RETURNS text CHARSET latin1
BEGIN
SET details = SUBSTRING_INDEX(details, "{", -1);
SET details = SUBSTRING_INDEX(details, "}", 1);
RETURN TRIM(
  BOTH '"' FROM SUBSTRING_INDEX(
    SUBSTRING_INDEX(
      SUBSTRING_INDEX(
        CONCAT('"":"",',details),
        CONCAT(
          '"',
          SUBSTRING_INDEX(required_field,'$.', -1),
          '":'
        ),
        -1
      ),
      ',"',
      1
    ),
    ':',
    -1
  )
) ;
END

Summarize

The above is a detailed example of how to parse JSON in MySQL (5.6 and below) introduced by the editor. I hope it will be helpful to everyone. If you have any questions, please leave me a message and the editor will reply to you in time. I would also like to thank everyone for their support of the 123WORDPRESS.COM website!
If you find this article helpful, please feel free to reprint it and please indicate the source. Thank you!

You may also be interested in:
  • Basic JSON Operation Guide in MySQL 5.7
  • MySQL 5.7 JSON type usage details
  • Instructions for using JSON operation functions in Mysql5.7
  • A brief discussion on MySQL 5.7 JSON format retrieval
  • How to query json in the database in mysql5.6 and below
  • Detailed explanation of JSON series operation functions in Mysql
  • MySQL operations: JSON data type operations
  • MySQL insert json problem
  • Example analysis of the usage of the new json field type in mysql5.7

<<:  VMwarea virtual machine installation win7 operating system tutorial diagram

>>:  Installation and configuration method of vue-route routing management

Recommend

Vue custom table column implementation process record

Table of contents Preface Rendering setTable comp...

Differences between this keyword in NodeJS and browsers

Preface Anyone who has learned JavaScript must be...

Mysql master/slave database synchronization configuration and common errors

As the number of visits increases, for some time-...

Several reasons for not compressing HTML

The reason is simple: In HTML documents, multiple ...

Three ways to draw a heart shape with CSS

Below, we introduce three ways to draw heart shap...

Vue realizes screen adaptation of large screen pages

This article shares the specific code of Vue to a...

Zabbix monitors mysql instance method

1. Monitoring planning Before creating a monitori...

HTML table markup tutorial (15): table title

<br />This tag can be used to directly add a...

Detailed analysis of when tomcat writes back the response datagram

The question arises This question arose when I wa...

Is it necessary to give alt attribute to img image tag?

Do you add an alt attribute to the img image tag? ...

CSS implements a pop-up window effect with a mask layer that can be closed

Pop-up windows are often used in actual developme...

JS cross-domain XML--with AS URLLoader

Recently, I received a requirement for function ex...

Detailed explanation of vuex persistence in practical application of vue

Table of contents vuex persistence Summarize vuex...