Rumah >pangkalan data >tutorial mysql >Bagaimanakah Fungsi JSON_TABLE MySQL Boleh Menukar Tatasusunan JSON kepada Baris?

Bagaimanakah Fungsi JSON_TABLE MySQL Boleh Menukar Tatasusunan JSON kepada Baris?

Patricia Arquette
Patricia Arquetteasal
2024-11-29 05:37:17828semak imbas

How Can MySQL's JSON_TABLE Function Convert JSON Arrays into Rows?

Menukar Tatasusunan JSON kepada Baris dalam MySQL

Dalam MySQL 5.7 dan versi terdahulu, memanipulasi JSON boleh menjadi mencabar, terutamanya apabila menukar tatasusunan JSON kepada barisan. Walau bagaimanapun, dalam MySQL 8, fungsi JSON_TABLE baharu menyediakan penyelesaian yang mudah.

Fungsi JSON_TABLE

Fungsi JSON_TABLE membolehkan anda mengekstrak data dengan mudah daripada dokumen dan peta JSON ia kepada skema jadual hubungan. Untuk menukar tatasusunan JSON kepada baris, gunakan sintaks berikut:

SELECT *
FROM JSON_TABLE(
  <json_array>,
  "$[*]"
  COLUMNS(
    <column_name> <data_type> PATH "$"
  )
) <table_alias>;

Contoh

Pertimbangkan tatasusunan JSON:

[5, 6, 7]

Anda boleh menukarnya menjadi jadual menggunakan JSON_TABLE:

SELECT *
FROM JSON_TABLE(
  '[5, 6, 7]',
  "$[*]"
  COLUMNS(
    Value INT PATH "$"
  )
) data;

Output akan be:

| Value |
|---|---|
| 5 |
| 6 |
| 7 |

Pemisahan Rentetan Umum

MySQL tidak mempunyai fungsi pemisahan rentetan asli. Walau bagaimanapun, anda boleh menggunakan JSON_TABLE untuk mencapai hasil yang serupa:

set @delimited = 'a,b,c';

SELECT *
FROM JSON_TABLE(
  CONCAT('["', REPLACE(@delimited, ',', '", "'), '"]'),
  "$[*]"
  COLUMNS(
    Value varchar(50) PATH "$"
  )
) data;

Ini akan memisahkan rentetan yang dipisahkan kepada tatasusunan JSON dan kemudian menukarnya kepada jadual.

Atas ialah kandungan terperinci Bagaimanakah Fungsi JSON_TABLE MySQL Boleh Menukar Tatasusunan JSON kepada Baris?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn