Menggunakan JSON di MySQL
在现代应用开发中,有效管理半结构化数据至关重要。MySQL 5.7 版本及以上版本内置了对 JSON 数据类型的支持,为关系型数据库中存储、查询和操作这类数据提供了强有力的工具。本文将介绍 MySQL 提供的核心 JSON 函数,并结合实际案例进行讲解,帮助您快速上手。
为什么选择 MySQL 的 JSON 功能?
在关系型数据库中使用 JSON 数据类型,可以简化半结构化或层级数据的处理流程,带来诸多优势:
- 灵活性: JSON 结构支持动态、层级数据的灵活存储。
- 内置函数: MySQL 提供高效的 JSON 数据查询、更新和验证函数。
- 集成性: 可以将关系型数据与 JSON 对象结合,实现混合数据模型。
-
创建 JSON 数据
利用 JSON_OBJECT()
和 JSON_ARRAY()
函数,可以方便地构建 JSON 对象或数组。
示例:
SELECT JSON_OBJECT('id', 1, 'name', 'Alice', 'roles', JSON_ARRAY('admin', 'editor')) AS json_data;
输出:
{"id": 1, "name": "Alice", "roles": ["admin", "editor"]}
-
存储 JSON 数据
使用 JSON 数据类型定义数据库列,即可存储 JSON 数据。
示例:
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"]}');
-
从 JSON 数据中提取数据
MySQL 提供多种函数用于从 JSON 文档中提取数据:
JSON_EXTRACT()
:使用 JSONPath 表达式获取指定值。->
运算符:JSON_EXTRACT()
的简写形式。
示例:
SELECT JSON_EXTRACT(details, '$.name') AS name, details->'$.age' AS age FROM users;
输出:
-
修改 JSON 数据
以下函数用于更新或添加 JSON 数据元素:
JSON_SET()
:插入或更新键值对。JSON_INSERT()
:仅当键不存在时插入。JSON_REPLACE()
:仅更新已存在的键值对。
示例:
UPDATE users SET details = JSON_SET(details, '$.city', 'New York') WHERE id = 1; SELECT details FROM users;
输出:
{"name": "Bob", "age": 30, "roles": ["viewer", "editor"], "city": "New York"}
-
删除键值对
使用 JSON_REMOVE()
函数删除 JSON 文档中的元素。
示例:
UPDATE users SET details = JSON_REMOVE(details, '$.roles') WHERE id = 1; SELECT details FROM users;
输出:
{"name": "Bob", "age": 30, "city": "New York"}
-
在 JSON 数据中搜索
JSON_CONTAINS()
函数用于检查 JSON 文档是否包含特定值。
示例:
SELECT JSON_CONTAINS(details, '"New York"', '$.city') AS has_city FROM users;
输出:
-
JSON 数据聚合
JSON_ARRAYAGG()
和 JSON_OBJECTAGG()
函数可以将查询结果聚合为 JSON 结构。
示例:
SELECT JSON_ARRAYAGG(name) AS names FROM ( SELECT JSON_EXTRACT(details, '$.name') AS name FROM users ) AS subquery;
输出:
["Bob"]
-
验证 JSON 数据
JSON_VALID()
函数用于检查字符串是否为有效的 JSON 数据。
示例:
SELECT JSON_VALID('{"key": "value"}') AS is_valid, JSON_VALID('invalid json') AS is_invalid;
输出:
-
格式化 JSON 输出
JSON_PRETTY()
函数将 JSON 数据格式化为易于阅读的格式。
示例:
SELECT JSON_PRETTY(details) AS pretty_json FROM users;
输出:
{ "name": "Bob", "age": 30, "city": "New York" }
其他 JSON 函数
MySQL 提供了丰富的 JSON 函数,本文仅介绍了部分常用函数。其他函数包括:JSON_ARRAY_APPEND()
、JSON_ARRAY_INSERT()
、JSON_CONTAINS_PATH()
、JSON_DEPTH()
、JSON_KEYS()
、JSON_LENGTH()
、JSON_MERGE_PATCH()
、JSON_MERGE_PRESERVE()
、JSON_OVERLAPS()
、JSON_QUOTE()
、JSON_SEARCH()
、JSON_STORAGE_FREE()
、JSON_STORAGE_SIZE()
、JSON_TABLE()
、JSON_TYPE()
、JSON_UNQUOTE()
等。
MySQL 的 JSON 函数为关系型数据库中半结构化数据的管理提供了强大的支持,简化了 JSON 数据的存储、查询和操作,为数据库设计提供了新的思路。 熟练掌握这些函数,将极大地提高开发效率。
Atas ialah kandungan terperinci Menggunakan JSON di MySQL. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat 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

Menggunakan perpustakaan Chrono di C membolehkan anda mengawal selang masa dan masa dengan lebih tepat. Mari kita meneroka pesona perpustakaan ini. Perpustakaan Chrono C adalah sebahagian daripada Perpustakaan Standard, yang menyediakan cara moden untuk menangani selang waktu dan masa. Bagi pengaturcara yang telah menderita dari masa. H dan CTime, Chrono tidak diragukan lagi. Ia bukan sahaja meningkatkan kebolehbacaan dan mengekalkan kod, tetapi juga memberikan ketepatan dan fleksibiliti yang lebih tinggi. Mari kita mulakan dengan asas -asas. Perpustakaan Chrono terutamanya termasuk komponen utama berikut: STD :: Chrono :: System_Clock: Mewakili jam sistem, yang digunakan untuk mendapatkan masa semasa. Std :: Chron

Mengukur prestasi thread di C boleh menggunakan alat masa, alat analisis prestasi, dan pemasa tersuai di perpustakaan standard. 1. Gunakan perpustakaan untuk mengukur masa pelaksanaan. 2. Gunakan GPROF untuk analisis prestasi. Langkah -langkah termasuk menambah pilihan -pg semasa penyusunan, menjalankan program untuk menghasilkan fail gmon.out, dan menghasilkan laporan prestasi. 3. Gunakan modul Callgrind Valgrind untuk melakukan analisis yang lebih terperinci. Langkah -langkah termasuk menjalankan program untuk menghasilkan fail callgrind.out dan melihat hasil menggunakan kcachegrind. 4. Pemasa tersuai secara fleksibel dapat mengukur masa pelaksanaan segmen kod tertentu. Kaedah ini membantu memahami sepenuhnya prestasi benang dan mengoptimumkan kod.

DMA di C merujuk kepada DirectMemoryAccess, teknologi akses memori langsung, yang membolehkan peranti perkakasan secara langsung menghantar data ke memori tanpa campur tangan CPU. 1) Operasi DMA sangat bergantung kepada peranti perkakasan dan pemacu, dan kaedah pelaksanaan berbeza dari sistem ke sistem. 2) Akses langsung ke memori boleh membawa risiko keselamatan, dan ketepatan dan keselamatan kod mesti dipastikan. 3) DMA boleh meningkatkan prestasi, tetapi penggunaan yang tidak wajar boleh menyebabkan kemerosotan prestasi sistem. Melalui amalan dan pembelajaran, kita dapat menguasai kemahiran menggunakan DMA dan memaksimumkan keberkesanannya dalam senario seperti penghantaran data berkelajuan tinggi dan pemprosesan isyarat masa nyata.

C berfungsi dengan baik dalam pengaturcaraan sistem operasi masa nyata (RTOS), menyediakan kecekapan pelaksanaan yang cekap dan pengurusan masa yang tepat. 1) C memenuhi keperluan RTO melalui operasi langsung sumber perkakasan dan pengurusan memori yang cekap. 2) Menggunakan ciri berorientasikan objek, C boleh merancang sistem penjadualan tugas yang fleksibel. 3) C menyokong pemprosesan gangguan yang cekap, tetapi peruntukan memori dinamik dan pemprosesan pengecualian mesti dielakkan untuk memastikan masa nyata. 4) Pemrograman templat dan fungsi sebaris membantu dalam pengoptimuman prestasi. 5) Dalam aplikasi praktikal, C boleh digunakan untuk melaksanakan sistem pembalakan yang cekap.

Mengendalikan paparan DPI yang tinggi di C boleh dicapai melalui langkah -langkah berikut: 1) Memahami DPI dan skala, gunakan API Sistem Operasi untuk mendapatkan maklumat DPI dan menyesuaikan output grafik; 2) Mengendalikan keserasian silang platform, gunakan perpustakaan grafik silang platform seperti SDL atau QT; 3) Melaksanakan pengoptimuman prestasi, meningkatkan prestasi melalui cache, pecutan perkakasan, dan pelarasan dinamik tahap butiran; 4) Selesaikan masalah biasa, seperti teks kabur dan elemen antara muka terlalu kecil, dan selesaikan dengan betul menggunakan skala DPI.

Kaedah yang cekap untuk memasukkan data dalam MySQL termasuk: 1. Menggunakan sintaks Insertinto ... Sintaks, 2. Menggunakan perintah LoadDatainFile, 3. Menggunakan pemprosesan transaksi, 4. Laraskan saiz batch, 5. Lumpuhkan pengindeks

Untuk melaksanakan reka bentuk gandingan longgar di C, anda boleh menggunakan kaedah berikut: 1. Gunakan antara muka, seperti menentukan antara muka logger dan melaksanakan filelogger dan consolelogger; 2. Suntikan ketergantungan, seperti kelas DataAccess menerima penunjuk pangkalan data melalui pembina; 3. Corak pemerhati, seperti kelas subjek memberitahu ConcreteObserver dan lain -lain. Melalui teknologi ini, kebergantungan antara modul dapat dikurangkan dan kebolehkerjaan dan fleksibiliti kod dapat ditingkatkan.

Di MySQL, tambah medan menggunakan alterTabletable_nameaddcolumnnew_columnvarchar (255) afterexisting_column, memadam medan menggunakan altertabletable_namedropcolumncolumn_to_drop. Apabila menambah medan, anda perlu menentukan lokasi untuk mengoptimumkan prestasi pertanyaan dan struktur data; Sebelum memadam medan, anda perlu mengesahkan bahawa operasi itu tidak dapat dipulihkan; Mengubah struktur jadual menggunakan DDL dalam talian, data sandaran, persekitaran ujian, dan tempoh masa beban rendah adalah pengoptimuman prestasi dan amalan terbaik.
