Dalam pembangunan aplikasi moden, mengurus data separa berstruktur adalah cabaran biasa. Sokongan MySQL untuk JSON, yang diperkenalkan dalam versi 5.7, menyediakan cara yang berkuasa untuk menyimpan, membuat pertanyaan dan memanipulasi data tersebut dalam pangkalan data hubungan. Siaran ini meneroka fungsi JSON penting yang MySQL tawarkan dengan contoh praktikal untuk membantu bermula.
Menyimpan data JSON dalam pangkalan data hubungan boleh memudahkan pengendalian data separa berstruktur atau hierarki. Ia membolehkan:
Anda boleh membina objek atau tatasusunan JSON menggunakan fungsi JSON_OBJECT() dan JSON_ARRAY().
Contoh:
SELECT JSON_OBJECT('id', 1, 'name', 'Alice', 'roles', JSON_ARRAY('admin', 'editor')) AS json_data;
Output:
{"id": 1, "name": "Alice", "roles": ["admin", "editor"]}
Untuk menyimpan data JSON, gunakan jenis data JSON untuk lajur.
Contoh:
CREATE TABLE users ( id INT AUTO_INCREMENT PRIMARY KEY, details JSON NOT NULL ); INSERT INTO users (details) VALUES ('{"name": "Bob", "age": 30, "roles": ["viewer", "editor"]}');
MySQL menyediakan beberapa fungsi untuk mengekstrak data daripada dokumen JSON:
Contoh:
SELECT JSON_EXTRACT(details, '$.name') AS name, details->'$.age' AS age FROM users;
Output:
Anda boleh mengemas kini atau menambah elemen pada data JSON dengan:
Contoh:
UPDATE users SET details = JSON_SET(details, '$.city', 'New York') WHERE id = 1; SELECT details FROM users;
Output:
{"name": "Bob", "age": 30, "roles": ["viewer", "editor"], "city": "New York"}
Gunakan JSON_REMOVE() untuk memadamkan elemen daripada dokumen JSON.
Contoh:
UPDATE users SET details = JSON_REMOVE(details, '$.roles') WHERE id = 1; SELECT details FROM users;
Output:
{"name": "Bob", "age": 30, "city": "New York"}
Fungsi JSON_CONTAINS() menyemak sama ada dokumen JSON mengandungi nilai tertentu.
Contoh:
SELECT JSON_CONTAINS(details, '"New York"', '$.city') AS has_city FROM users;
Output:
Fungsi JSON_ARRAYAGG() dan JSON_OBJECTAGG() membantu mengagregatkan hasil pertanyaan ke dalam struktur JSON.
Contoh:
SELECT JSON_ARRAYAGG(name) AS names FROM ( SELECT JSON_EXTRACT(details, '$.name') AS name FROM users ) AS subquery;
Output:
SELECT JSON_OBJECT('id', 1, 'name', 'Alice', 'roles', JSON_ARRAY('admin', 'editor')) AS json_data;
Fungsi JSON_VALID() menyemak sama ada rentetan adalah JSON yang sah.
Contoh:
{"id": 1, "name": "Alice", "roles": ["admin", "editor"]}
Output:
Gunakan JSON_PRETTY() untuk pemformatan JSON yang boleh dibaca manusia.
Contoh:
CREATE TABLE users ( id INT AUTO_INCREMENT PRIMARY KEY, details JSON NOT NULL ); INSERT INTO users (details) VALUES ('{"name": "Bob", "age": 30, "roles": ["viewer", "editor"]}');
Output:
SELECT JSON_EXTRACT(details, '$.name') AS name, details->'$.age' AS age FROM users;
MySQL menawarkan pelbagai fungsi JSON melebihi fungsi yang dibincangkan secara terperinci. Di bawah ialah fungsi JSON yang lain:
Fungsi JSON MySQL menyediakan alatan berkuasa untuk mengurus data separa berstruktur dalam pangkalan data hubungan. Mereka memudahkan untuk menyimpan, membuat pertanyaan dan memanipulasi JSON secara langsung dalam SQL. Memahami fungsi ini boleh membantu memudahkan aliran kerja dan membuka pendekatan baharu kepada reka bentuk pangkalan data.
Atas ialah kandungan terperinci Bekerja dengan JSON dalam MySQL. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!