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
Lepaskan: 2024-11-29 05:37:17
asal
769 orang telah melayarinya

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>;
Salin selepas log masuk

Contoh

Pertimbangkan tatasusunan JSON:

[5, 6, 7]
Salin selepas log masuk

Anda boleh menukarnya menjadi jadual menggunakan JSON_TABLE:

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

Output akan be:

| Value |
|---|---|
| 5 |
| 6 |
| 7 |
Salin selepas log masuk

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;
Salin selepas log masuk

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!

sumber:php.cn
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan