


Bagaimanakah Fungsi JSON_TABLE MySQL Boleh Menukar Tatasusunan JSON kepada Baris?
Nov 29, 2024 am 05:37 AMMenukar 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!

Artikel Panas

Alat panas Tag

Artikel Panas

Tag artikel panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Kurangkan penggunaan memori MySQL di Docker

Bagaimana anda mengubah jadual di MySQL menggunakan pernyataan Alter Table?

Cara menyelesaikan masalah MySQL tidak dapat membuka perpustakaan bersama

Apa itu SQLite? Gambaran Keseluruhan Komprehensif

Jalankan MySQL di Linux (dengan/tanpa bekas podman dengan phpmyadmin)

Menjalankan Pelbagai Versi MySQL di MacOS: Panduan Langkah demi Langkah

Bagaimanakah saya menjamin MySQL terhadap kelemahan biasa (suntikan SQL, serangan kekerasan)?

Bagaimana saya mengkonfigurasi penyulitan SSL/TLS untuk sambungan MySQL?
