Rumah  >  Artikel  >  pangkalan data  >  Bagaimana untuk Mendapatkan Objek Tertentu daripada Lajur JSON dalam MySQL Berdasarkan Pasangan Nilai Kunci?

Bagaimana untuk Mendapatkan Objek Tertentu daripada Lajur JSON dalam MySQL Berdasarkan Pasangan Nilai Kunci?

Susan Sarandon
Susan Sarandonasal
2024-11-03 15:09:30442semak imbas

How to Retrieve a Specific Object from a JSON Column in MySQL Based on Key-Value Pair?

MySQL JSON: Mencari Objek Berdasarkan Nilai Utama

Jadual MySQL sering menggunakan lajur JSON untuk menyimpan struktur data yang kompleks. Apabila bekerja dengan JSON, tugas biasa adalah untuk mendapatkan semula objek tertentu berdasarkan pasangan nilai kunci. Walau bagaimanapun, mencari objek secara langsung mungkin tidak selalunya mudah.

Contoh Skema JSON:

Pertimbangkan skema berikut:

<code class="sql">CREATE TABLE `fields` (
  `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
  `label` varchar(64) COLLATE utf8mb4_unicode_ci NOT NULL,
  `options` json DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;</code>

Dengan sampel data:

<code class="sql">INSERT INTO `fields` (label, options) VALUES
(
  'My Field', 
  '[{"text": "Grass", "value": "1"}, {"text": "Synthetic (New Type - Soft)", "value": "2"}, {"text": "Synthetic  (Old Type - Hard)", "value": "3"}, {"text": "Gravel", "value": "5"}, {"text": "Clay", "value": "6"}, {"text": "Sand", "value": "7"}, {"text": "Grass/Synthetic Mix", "value": "8"}]'
);</code>

Masalah:

Andaikan kita ingin mendapatkan rentetan "Rumput" daripada tatasusunan JSON pilihan, dengan mengetahui bahawa "nilai" yang sepadan ialah " 1." Menggunakan JSON_EXTRACT() sahaja memerlukan indeks tatasusunan, yang mungkin tidak tersedia dengan mudah.

Penyelesaian 1: Menggunakan JSON_SEARCH() dan Manipulasi Rentetan Mengerikan

Pendekatan ini menggabungkan JSON_SEARCH() untuk mencari sebahagian indeks dan kemudian mengalih keluar bahagian yang tidak diingini daripada rentetan:

<code class="sql">SELECT
JSON_EXTRACT(`options`,CONCAT('$[',REPLACE(REPLACE(JSON_SEARCH(`options`, 'one', '1'), '"$[', ''), '].value"', ''), '].text'))
from `fields`;</code>

Penyelesaian 2: Menggunakan JSON_TABLE()

MySQL 8.0 memperkenalkan JSON_TABLE () untuk memudahkan tugas ini:

<code class="sql">select field_options.* from fields cross join 
json_table(fields.options, 
'$[*]' columns(
  text text path '$.text',
  value text path '$.value'
 )
) as field_options 
where field_options.value = 1;</code>

Pendekatan Alternatif: Model Data Perhubungan

Untuk struktur data yang lebih mudah seperti contoh ini, pertimbangkan untuk menyimpan data dalam jadual hubungan dengan lajur untuk pasangan kunci dan nilai, membolehkan carian terus:

<code class="sql">SELECT * FROM field_options WHERE value = '1';</code>

Atas ialah kandungan terperinci Bagaimana untuk Mendapatkan Objek Tertentu daripada Lajur JSON dalam MySQL Berdasarkan Pasangan Nilai Kunci?. 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