JSON 数组在 MySQL 中存储与读取的 PHP 教程

霞舞
发布: 2025-11-16 11:04:02
原创
172人浏览过

json 数组在 mysql 中存储与读取的 php 教程

本教程详细讲解了如何使用 PHP 将 JSON 数组有效地存储到 MySQL 数据库中,并提供示例代码演示了如何提取 JSON 数组中的特定部分并将其转换为可存储的 JSON 字符串。同时,讨论了在数据库中存储 JSON 数据的注意事项,以及如何在 PHP 中进行数据的读取和解析。

将 JSON 数组存储到 MySQL 数据库

在 Web 开发中,经常需要将复杂的数据结构(例如 JSON 数组)存储到数据库中。MySQL 5.7.22 及更高版本支持 JSON 数据类型,可以直接存储 JSON 文档。对于旧版本的 MySQL,则需要将 JSON 数组转换为字符串进行存储。本教程将重点介绍如何使用 PHP 将 JSON 数组转换为字符串,并将其存储到 MySQL 数据库中。

准备工作

  1. MySQL 数据库:确保你已经安装并配置了 MySQL 数据库。

  2. PHP 环境:确保你已经安装并配置了 PHP 环境,并且已经安装了 MySQL 扩展。

    立即学习PHP免费学习笔记(深入)”;

  3. 数据库表:创建一个用于存储 JSON 数据的数据库表。例如:

    CREATE TABLE `json_data` (
      `id` INT AUTO_INCREMENT PRIMARY KEY,
      `us_id` INT,
      `stu_id` INT,
      `class_id` INT,
      `req_x` TEXT
    );
    登录后复制

    这里,req_x 字段用于存储 JSON 数组的字符串表示。TEXT 类型适用于存储较长的字符串。如果你使用的是 MySQL 5.7.22 或更高版本,可以将 req_x 字段的数据类型设置为 JSON。

    Find JSON Path Online
    Find JSON Path Online

    Easily find JSON paths within JSON objects using our intuitive Json Path Finder

    Find JSON Path Online 30
    查看详情 Find JSON Path Online

PHP 代码示例

假设你有一个 JSON 字符串,并且只需要将 req_x 字段的内容存储到数据库中。以下是一个示例 PHP 代码:

<?php

// 数据库连接信息
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "database_name";

// 创建连接
$conn = new mysqli($servername, $username, $password, $dbname);

// 检测连接
if ($conn->connect_error) {
  die("连接失败: " . $conn->connect_error);
}

// 原始 JSON 字符串
$start = '{
    "us_id":"1",
    "stu_id":"6",
    "class_id":"3",
    "req_x":[
        { "u_id":"1", "u_details":"testing user", "charges":"12.50"},
        { "u_id":"2", "u_details":"testing user 2", "charges":"10.50" },
        { "u_id":"3", "u_details":"testing user 3", "charges":"9.50" }
    ]
}';

// 解析 JSON 字符串
$obj = json_decode($start);

// 提取 req_x 数组
$arr = $obj->req_x;

// 将 req_x 数组转换为 JSON 字符串
$json_req_x = json_encode($arr);

// 准备 SQL 语句
$us_id = $obj->us_id;
$stu_id = $obj->stu_id;
$class_id = $obj->class_id;
$sql = "INSERT INTO json_data (us_id, stu_id, class_id, req_x) VALUES ('$us_id', '$stu_id', '$class_id', '$json_req_x')";

// 执行 SQL 语句
if ($conn->query($sql) === TRUE) {
  echo "数据插入成功";
} else {
  echo "Error: " . $sql . "<br>" . $conn->error;
}

// 关闭连接
$conn->close();

?>
登录后复制

代码解释:

  1. 数据库连接:首先,建立与 MySQL 数据库的连接。
  2. JSON 解析:使用 json_decode() 函数将 JSON 字符串解析为 PHP 对象。
  3. 提取数据:从解析后的对象中提取 req_x 数组。
  4. JSON 编码:使用 json_encode() 函数将 req_x 数组转换为 JSON 字符串。
  5. SQL 插入:构建 SQL 插入语句,将 us_id、stu_id、class_id 以及 JSON 字符串插入到数据库表中。
  6. 执行查询:执行 SQL 语句,并将结果输出。
  7. 关闭连接:关闭数据库连接。

从数据库读取 JSON 数据

从数据库中读取 JSON 数据并解析的 PHP 代码如下:

<?php

// 数据库连接信息
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "database_name";

// 创建连接
$conn = new mysqli($servername, $username, $password, $dbname);

// 检测连接
if ($conn->connect_error) {
  die("连接失败: " . $conn->connect_error);
}

// SQL 查询语句
$sql = "SELECT req_x FROM json_data WHERE id = 1"; // 假设要读取 id 为 1 的数据
$result = $conn->query($sql);

if ($result->num_rows > 0) {
  // 输出数据
  while($row = $result->fetch_assoc()) {
    // 获取 JSON 字符串
    $json_req_x = $row["req_x"];

    // 解析 JSON 字符串为 PHP 数组
    $req_x_array = json_decode($json_req_x, true); // 第二个参数为 true 表示返回数组

    // 打印数组内容
    echo "<pre>";
    print_r($req_x_array);
    echo "</pre>";
  }
} else {
  echo "没有找到数据";
}

// 关闭连接
$conn->close();

?>
登录后复制

代码解释:

  1. 数据库连接:建立与 MySQL 数据库的连接。
  2. SQL 查询:构建 SQL 查询语句,从数据库表中选择 req_x 字段。
  3. 执行查询:执行 SQL 语句,并将结果输出。
  4. JSON 解析:使用 json_decode() 函数将 JSON 字符串解析为 PHP 数组。json_decode() 的第二个参数设置为 true,表示将 JSON 对象转换为 PHP 数组。
  5. 输出数据:将解析后的 PHP 数组打印出来。
  6. 关闭连接:关闭数据库连接。

注意事项

  • 数据类型:在 MySQL 5.7.22 及更高版本中,建议使用 JSON 数据类型存储 JSON 文档,这样可以提高查询效率和数据验证能力。
  • 安全性:在构建 SQL 语句时,务必使用预处理语句或转义函数,以防止 SQL 注入攻击。
  • 错误处理:在解析 JSON 字符串时,需要进行错误处理,以防止因 JSON 格式错误导致程序崩溃。
  • 字符编码:确保数据库连接和数据表都使用 UTF-8 字符编码,以支持存储各种字符。

总结

本教程介绍了如何使用 PHP 将 JSON 数组存储到 MySQL 数据库中,并从数据库中读取 JSON 数据。通过使用 json_encode() 和 json_decode() 函数,可以方便地在 PHP 和 MySQL 之间进行 JSON 数据的转换。在实际开发中,需要根据具体情况选择合适的数据类型和存储方式,并注意数据的安全性和完整性。

以上就是JSON 数组在 MySQL 中存储与读取的 PHP 教程的详细内容,更多请关注php中文网其它相关文章!

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号