Menggunakan Medan JSON MySQL untuk Gabungan Jadual Kompleks
Masalah:
Dalam pangkalan data MySQL skema, medan JSON menyimpan senarai ID. Matlamatnya adalah untuk melaksanakan operasi pada medan JSON ini dan menggunakan keputusan dalam pertanyaan SQL untuk menyertai jadual pengguna dengan jadual kumpulan pengguna.
Contoh Senario:
Pertimbangkan jadual berikut:
CREATE TABLE user ( user_id INT, user_name VARCHAR(50), user_groups JSON ); CREATE TABLE user_group ( user_group_id INT, group_name VARCHAR(50) );
Dengan data berikut:
INSERT INTO user_group (user_group_id, group_name) VALUES (1, 'Group A'); INSERT INTO user_group (user_group_id, group_name) VALUES (2, 'Group B'); INSERT INTO user_group (user_group_id, group_name) VALUES (3, 'Group C'); INSERT INTO user (user_id, user_name, user_groups) VALUES (101, 'John', '[1,3]');
Keputusan yang Diingini:
Hasil yang dikehendaki ialah pertanyaan yang mendapatkan semula data berikut:
user_id | user_name | user_group_id | group_name| ------------------------------------------------- 101 | John | 1 | Group A 101 | John | 3 | Group C
Penyelesaian:
Penyelesaian melibatkan penggunaan fungsi JSON_CONTAINS untuk menyemak sama ada ID kumpulan pengguna wujud dalam medan JSON pengguna jadual.
<code class="sql">SELECT u.user_id, u.user_name, g.user_group_id, g.group_name FROM user u LEFT JOIN user_group g on JSON_CONTAINS(u.user_groups, CAST(g.user_group_id as JSON), '$')</code>
Nota:
Pengendali $ dalam fungsi JSON_CONTAINS mewakili punca dokumen JSON.
Atas ialah kandungan terperinci Bagaimanakah anda boleh menyertai jadual MySQL berdasarkan data dalam medan JSON?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!