将扁平JSON数据转换为MySQL分层结构教程

将扁平JSON数据转换为MySQL分层结构教程

本教程详细介绍了如何将包含分层信息的扁平json字符串(例如“clothes – pants – jeans”)导入mysql数据库,并构建出具有父子关系的层级结构。通过php脚本解析json、拆分字符串并巧妙管理父级id,确保数据正确地存储为可查询的树状结构,解决在创建层级关系时常见的父级id关联错误。

从扁平JSON构建MySQL分层结构

在数据处理和存储中,我们经常会遇到需要将某种格式的扁平数据转换为具有层级关系的结构。本教程将指导您如何使用PHP将包含以特定分隔符表示的层级信息的JSON数据导入MySQL数据库,并构建一个可查询的树状结构。

1. 问题背景与数据结构

假设我们有一个JSON文件,其中包含产品类别信息,但这些信息是以扁平的、通过分隔符连接的字符串形式存在的:

[  {"productCategory":"Clothes - Pants - Jeans"},  {"productCategory":"Clothes - Pants - Chinos"},  {"productCategory":"Electronics - Laptops - Gaming"}]

我们的目标是将这些类别导入到MySQL数据库中,并形成一个具有父子关系的层级结构。期望的数据库表结构如下:

taxonomy_id taxonomy_name taxonomy_parent taxonomy_type

1Clothes0Category2Pants1Category3Jeans2Category4Chinos2Category5Electronics0Category6Laptops5Category7Gaming6Category

其中,taxonomy_id 是主键,taxonomy_name 是类别名称,taxonomy_parent 指向其父类别的 taxonomy_id(根类别为0),taxonomy_type 标识类别类型。

2. 核心思路与挑战

处理这种数据转换的核心思路是:

解析JSON: 读取JSON文件并将其解码为PHP数组。拆分层级字符串: 使用分隔符(例如 ‘-‘)将每个 productCategory 字符串拆分成独立的层级名称数组。迭代处理层级: 遍历拆分后的层级名称数组,为每个层级名称在数据库中创建或查找对应的条目。管理父级ID: 这是最关键的一步。在处理每个子层级时,需要知道其直接父级的 taxonomy_id。

最初的尝试可能遇到的问题是,在处理子层级时,父级ID的跟踪逻辑可能出现偏差,导致某些子类别的 taxonomy_parent 字段未能正确关联到其父级。

3. PHP实现:逐步构建层级

我们将使用PHP来完成这一任务。为了简化数据库操作,我们假设存在一个 Insert_Taxonomy 类,它封装了与数据库交互的方法:

Exists_Taxonomy_Name($name): 检查给定名称的类别是否已存在。Get_Taxonomy_Id($name): 根据类别名称获取其 taxonomy_id。如果名称为0,则返回0(表示根类别)。create_taxonomy($args): 创建新的类别记录,$args 数组包含名称、父ID和类型。

完整解决方案代码:

 $current_category_name ) {        // 1. 检查当前类别名称是否已存在于数据库中        $exists_tax_name = $taxonomy->Exists_Taxonomy_Name($current_category_name);        // 2. 获取当前类别的父级ID        // $previous_value 存储的是父级“名称”(或0),需要通过 Get_Taxonomy_Id 转换为实际的ID        $parent_id = $taxonomy->Get_Taxonomy_Id($previous_value);        // 3. 如果当前类别不存在,则插入新记录        if ( empty( $exists_tax_name ) ) {            $args = array($current_category_name, $parent_id, 'category');            $taxonomy->create_taxonomy($args);        }        // 4. 更新 previous_value 为当前类别名称,以便在下一次循环中作为子类别的父级        // 这一步至关重要,确保了正确的父子关系链        $previous_value = $current_category_name;    }}?>

4. 代码解析与关键点

文件读取与解码:

$string = file_get_contents("category.json");$json_decode = json_decode($string, true);

这部分负责读取JSON文件并将其转换为PHP数组,true 参数确保解码为关联数组。

实例化数据库操作类:

$taxonomy = new Insert_Taxonomy();

在循环外部实例化 Insert_Taxonomy 对象,避免在每次迭代中重复创建,提高效率。

拆分与清理:

$split_categories = explode( '-', $category_full_path );$trimmed_categories = array_map('trim', $split_categories);

explode 函数将字符串按 ‘-‘ 分隔符拆分为数组。array_map(‘trim’, …) 用于移除每个子字符串两端的空白,确保数据干净。

父级ID跟踪 ($previous_value):

$previous_value = 0; // 初始化为0,表示根类别的父级// ...$parent_id = $taxonomy->Get_Taxonomy_Id($previous_value);// ...$previous_value = $current_category_name; // 更新为当前类别名称

这是解决层级关系的关键。$previous_value 变量在每次内部循环中存储 前一个 已经处理过的类别名称(或0),这个名称随后被用来通过 Get_Taxonomy_Id 方法获取其对应的 taxonomy_id,作为当前类别的 taxonomy_parent。

操作顺序的重要性:

$exists_tax_name = $taxonomy->Exists_Taxonomy_Name($current_category_name); // 1. 检查是否存在$parent_id = $taxonomy->Get_Taxonomy_Id($previous_value); // 2. 获取父IDif ( empty( $exists_tax_name ) ) { // 3. 如果不存在则插入    $args = array($current_category_name, $parent_id, 'category');    $taxonomy->create_taxonomy($args);}$previous_value = $current_category_name; // 4. 更新previous_value

正确的执行顺序是:

首先,检查当前类别是否已存在。然后,根据 previous_value 获取当前类别的父级ID。这一步必须在检查类别是否存在之前,因为即使类别已存在,我们也需要 previous_value 来更新它,或者在后续循环中作为下一个子类别的父级。如果类别不存在,则使用获取到的 parent_id 插入新记录。最后,将 current_category_name 赋值给 previous_value,为下一个层级的处理做好准备。这个顺序确保了无论是插入新类别还是仅仅更新 previous_value 以供后续使用,parent_id 都能正确地被计算。

5. Insert_Taxonomy 类(示例)

为了使上述代码能够运行,Insert_Taxonomy 类可能看起来像这样(仅为示例,实际实现需根据您的数据库连接和ORM库进行调整):

pdo = new PDO("mysql:host=localhost;dbname=your_db", "user", "pass");        // 为简化示例,我们假设连接已存在或通过其他方式获取        // 这里只是一个占位符,实际需要您自己的数据库连接代码        $this->pdo = null; // 实际应为有效的PDO对象        error_log("Insert_Taxonomy class initialized. (Database connection assumed)");    }    /**     * 检查分类名称是否存在     * @param string $name 分类名称     * @return bool 如果存在则返回true,否则返回false     */    public function Exists_Taxonomy_Name($name) {        if ($name === 0) return true; // 根节点始终被认为“存在”        // 实际查询数据库        // $stmt = $this->pdo->prepare("SELECT COUNT(*) FROM taxonomy_table WHERE taxonomy_name = ?");        // $stmt->execute([$name]);        // return $stmt->fetchColumn() > 0;        error_log("Checking if taxonomy name '{$name}' exists.");        // 模拟返回        return false; // 假设默认不存在,以便创建    }    /**     * 根据分类名称获取ID     * @param string|int $name 分类名称或0(表示根)     * @return int 分类ID,如果不存在或为0则返回0     */    public function Get_Taxonomy_Id($name) {        if ($name === 0) {            return 0; // 根分类的ID为0        }        // 实际查询数据库        // $stmt = $this->pdo->prepare("SELECT taxonomy_id FROM taxonomy_table WHERE taxonomy_name = ?");        // $stmt->execute([$name]);        // $result = $stmt->fetch(PDO::FETCH_ASSOC);        // return $result ? $result['taxonomy_id'] : 0;        error_log("Getting taxonomy ID for name '{$name}'.");        // 模拟返回一个ID,实际应从数据库获取        // 在实际运行中,如果名称不存在,这里应返回0或抛出错误        return crc32($name); // 简单模拟一个ID    }    /**     * 创建新的分类记录     * @param array $args 包含 [name, parent_id, type]     * @return bool 插入成功返回true,否则返回false     */    public function create_taxonomy($args) {        list($name, $parent_id, $type) = $args;        // 实际插入数据库        // $stmt = $this->pdo->prepare("INSERT INTO taxonomy_table (taxonomy_name, taxonomy_parent, taxonomy_type) VALUES (?, ?, ?)");        // return $stmt->execute([$name, $parent_id, $type]);        error_log("Creating taxonomy: Name='{$name}', ParentID='{$parent_id}', Type='{$type}'.");        return true; // 模拟成功    }}?>

6. 注意事项与最佳实践

幂等性: 确保您的脚本可以重复运行而不会创建重复的数据。本教程中的 Exists_Taxonomy_Name 方法正是为了实现这一点。错误处理: 在实际生产环境中,您应该为文件操作(file_get_contents)、JSON解码(json_decode)以及所有数据库操作添加适当的错误处理机制。数据库事务: 对于批量数据插入,考虑使用数据库事务。如果中间发生错误,可以回滚所有已执行的操作,保持数据一致性。性能优化: 对于非常大的JSON文件和大量类别,可以考虑批量插入或优化数据库查询,例如一次性获取所有现有类别的名称和ID,而不是在每次循环中都进行查询。灵活性: 如果分隔符可能变化,可以将其定义为配置项。

7. 总结

通过本教程,您应该已经掌握了如何将扁平的、分隔符连接的JSON数据转换为MySQL数据库中的分层结构。关键在于正确解析数据,并巧妙地管理父级ID的跟踪逻辑,确保每个子类别都能准确地关联到其直接父级。这种方法不仅适用于产品类别,也适用于任何需要构建树状或层级关系的数据导入场景。

以上就是将扁平JSON数据转换为MySQL分层结构教程的详细内容,更多请关注php中文网其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1328478.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月12日 14:45:56
下一篇 2025年12月12日 14:46:11

相关推荐

  • 网络进化!

    Web 应用程序从静态网站到动态网页的演变是由对更具交互性、用户友好性和功能丰富的 Web 体验的需求推动的。以下是这种范式转变的概述: 1. 静态网站(1990 年代) 定义:静态网站由用 HTML 编写的固定内容组成。每个页面都是预先构建并存储在服务器上,并且向每个用户传递相同的内容。技术:HT…

    2025年12月24日
    000
  • 为什么多年的经验让我选择全栈而不是平均栈

    在全栈和平均栈开发方面工作了 6 年多,我可以告诉您,虽然这两种方法都是流行且有效的方法,但它们满足不同的需求,并且有自己的优点和缺点。这两个堆栈都可以帮助您创建 Web 应用程序,但它们的实现方式却截然不同。如果您在两者之间难以选择,我希望我在两者之间的经验能给您一些有用的见解。 在这篇文章中,我…

    2025年12月24日
    000
  • 深入理解CSS框架与JS之间的关系

    深入理解CSS框架与JS之间的关系 在现代web开发中,CSS框架和JavaScript (JS) 是两个常用的工具。CSS框架通过提供一系列样式和布局选项,可以帮助我们快速构建美观的网页。而JS则提供了一套功能强大的脚本语言,可以为网页添加交互和动态效果。本文将深入探讨CSS框架和JS之间的关系,…

    2025年12月24日
    000
  • HTML+CSS+JS实现雪花飘扬(代码分享)

    使用html+css+js如何实现下雪特效?下面本篇文章给大家分享一个html+css+js实现雪花飘扬的示例,希望对大家有所帮助。 很多南方的小伙伴可能没怎么见过或者从来没见过下雪,今天我给大家带来一个小Demo,模拟了下雪场景,首先让我们看一下运行效果 可以点击看看在线运行:http://hai…

    2025年12月24日 好文分享
    500
  • 10款好看且实用的文字动画特效,让你的页面更吸引人!

    图片和文字是网页不可缺少的组成部分,图片运用得当可以让网页变得生动,但普通的文字不行。那么就可以给文字添加一些样式,实现一下好看的文字效果,让页面变得更交互,更吸引人。下面创想鸟就来给大家分享10款文字动画特效,好看且实用,快来收藏吧! 1、网页玻璃文字动画特效 模板简介:使用css3制作网页渐变底…

    2025年12月24日 好文分享
    000
  • tp5如何引入css文件

    tp5引入css文件的方法:1、将css文件放在public目录下的static文件里即可;2、在页面引入中写上“”语句即可。 本教程操作环境:windows7系统、CSS3&&HTML5版、Dell G3电脑。 其实很简单,只需要将css,js,image文件放在这个目录下即可 页…

    2025年12月24日
    000
  • 网页设计css样式代码大全,快来收藏吧!

    减少很多不必要的代码,html+css可以很方便的进行网页的排版布局。小伙伴们收藏好哦~ 一.文本设置    1、font-size: 字号参数  2、font-style: 字体格式 3、font-weight: 字体粗细 4、颜色属性 立即学习“前端免费学习笔记(深入)”; color: 参数 …

    2025年12月24日
    000
  • css中id选择器和class选择器有何不同

    之前的文章《什么是CSS语法?详细介绍使用方法及规则》中带了解CSS语法使用方法及规则。下面本篇文章来带大家了解一下CSS中的id选择器与class选择器,介绍一下它们的区别,快来一起学习吧!! id选择器和class选择器介绍 CSS中对html元素的样式进行控制是通过CSS选择器来完成的,最常用…

    2025年12月24日
    000
  • 聊聊CSS 与 JS 是如何阻塞 DOM 解析和渲染的

    本篇文章给大家介绍一下css和js阻塞 dom 解析和渲染的原理。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 hello~各位亲爱的看官老爷们大家好。估计大家都听过,尽量将CSS放头部,JS放底部,这样可以提高页面的性能。然而,为什么呢?大家有考虑过么?很长一段时间,我都是知其…

    2025年12月24日
    200
  • js如何修改css样式

    js修改css样式的方法:1、使用【obj.className】来修改样式表的类名;2、使用【obj.style.cssTest】来修改嵌入式的css;3、使用【obj.className】来修改样式表的类名;4、使用更改外联的css。 本教程操作环境:windows7系统、css3版,DELL G…

    2025年12月24日
    000
  • 如何使用纯CSS、JS实现图片轮播效果

    本篇文章给大家详细介绍一下使用纯css、js实现图片轮播效果的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 .carousel {width: 648px;height: 400px;margin: 0 auto;text-align: center;position: a…

    2025年12月24日
    000
  • js如何修改css

    js修改css的方法:1、使用【obj.style.cssTest】来修改嵌入式的css;2、使用【bj.className】来修改样式表的类名;3、使用更改外联的css文件,从而改变元素的css。 本教程操作环境:windows7系统、css3版,DELL G3电脑。 js修改css的方法: 方法…

    2025年12月24日
    000
  • js如何改变css样式

    js改变css样式的方法:1、使用cssText方法;2、使用【setProperty()】方法;3、使用css属性对应的style属性。 本教程操作环境:windows7系统、css3版,DELL G3电脑。 js改变css样式的方法: 第一种:用cssText div.style.cssText…

    2025年12月24日
    000
  • 为什么css放上面js放下面

    css放上面js放下面的原因:1、在加载html生成DOM tree的时候,可以同时对DOM tree进行渲染,这样可以防止闪跳,白屏或者布局混乱;2、javascript加载后会立即执行,同时会阻塞后面的资源加载。 本文操作环境:Windows7系统、HTML5&&CSS3版,DE…

    2025年12月24日
    000
  • 推荐六款移动端 UI 框架

    作为一个前端人员来说,总结几款相对来说不错的用于移动端开发的UI框架是非常必要的,以下几种移动端UI框架就能基本满足工作中开发需要,根据项目需求,选用合适的框架搭建项目,更能容易提高开发效率。 一、MUI         最接近原生APP体验的高性能前端框架,追求性能体验,是我们开始启动MUI项目的…

    2025年12月24日
    000
  • CSS如何实现任意角度的扇形(代码示例)

    本篇文章给大家带来的内容是关于CSS如何实现任意角度的扇形(代码示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 扇形制作原理,底部一个纯色原形,里面2个相同颜色的半圆,可以是白色,内部半圆按一定角度变化,就可以产生出扇形效果 扇形绘制 .shanxing{ position:…

    2025年12月24日
    000
  • css如何实现图片的旋转展示效果(代码示例)

    本篇文章给大家带来内容是通过代码示例介绍使用css+js实现图片的旋转展示,制作一个手动操作的“无限”照片轮播图。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 下面我们就开始介绍如何实现效果。 1、构建图像轮播框架 首先是HTML。它有点难以阅读,因为我们删除了元素之间的任何空格…

    2025年12月24日
    000
  • css3+js实现烟花绽放的动画效果(代码示例)

    本篇文章给大家介绍通过js+css3的transforms属性和keyframes属性来实现烟花绽放的动画效果的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 首先我们来看看效果: 动画的实现原理: 动画使用了两个关键帧(keyframes): 一个是烟花筒上升的轨迹,另一个…

    2025年12月24日
    000
  • css+js如何在幻灯片上添加文字?实现幻灯片的旋转切换(附代码)

    本篇文章给大家带来的内容是介绍css+js如何在幻灯片上添加文字?实现幻灯片的旋转切换(附代码)。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 在之前的文章【css如何实现幻灯片效果?幻灯片的实现方法】中介绍了实现淡入淡出幻灯片的实现方法,本篇文章就在其基础上去解释如何在幻灯片上…

    2025年12月24日
    000
  • css+js如何实现简单的动态进度条效果?(代码实例)

    css+js如何实现简单的动态进度条?本篇文章就给大家用css+js制作一个简单的动态进度条效果,并将页面动态进度条滚动加载的代码分享给大家,感兴趣的小伙伴可以参考借鉴一下,希望对你们有所帮助。 我们要知道,这里主要使用了css3的animation动画属性,首先将进度条设置为一个初始宽度为0,背景…

    2025年12月24日
    000

发表回复

登录后才能评论
关注微信