首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

从父子id的原始数据创建Json层次结构

,可以通过以下步骤实现:

  1. 首先,了解父子id的原始数据结构。通常,这种数据结构包含两个字段:一个是节点的唯一标识符,另一个是该节点的父节点标识符。例如,可以使用以下格式表示:
代码语言:txt
复制
[
  { "id": 1, "parent_id": null },
  { "id": 2, "parent_id": 1 },
  { "id": 3, "parent_id": 1 },
  { "id": 4, "parent_id": 2 },
  { "id": 5, "parent_id": 2 },
  { "id": 6, "parent_id": 3 },
  { "id": 7, "parent_id": 3 }
]
  1. 创建一个空的Json对象,用于存储层次结构数据。例如:
代码语言:txt
复制
let jsonHierarchy = {};
  1. 遍历原始数据,将每个节点添加到Json层次结构中。对于每个节点,首先检查其父节点是否存在于Json层次结构中。如果存在,则将当前节点添加为父节点的子节点;如果不存在,则将当前节点作为根节点添加到Json层次结构中。以下是一个示例实现:
代码语言:txt
复制
for (let i = 0; i < rawData.length; i++) {
  let node = rawData[i];
  let nodeId = node.id;
  let parentNodeId = node.parent_id;

  // Check if parent node exists in the hierarchy
  if (jsonHierarchy[parentNodeId]) {
    // Parent node exists, add current node as its child
    if (!jsonHierarchy[parentNodeId].children) {
      jsonHierarchy[parentNodeId].children = [];
    }
    jsonHierarchy[parentNodeId].children.push(node);
  } else {
    // Parent node does not exist, add current node as root
    jsonHierarchy[nodeId] = node;
  }
}
  1. 最后,将Json层次结构转换为字符串形式,以便在需要时进行使用。可以使用JSON.stringify()方法将其转换为字符串。例如:
代码语言:txt
复制
let jsonHierarchyString = JSON.stringify(jsonHierarchy);
console.log(jsonHierarchyString);

通过以上步骤,你可以从父子id的原始数据创建一个完整的Json层次结构。这种层次结构可以方便地表示和操作树形数据,适用于各种场景,如组织结构、目录结构等。

腾讯云相关产品和产品介绍链接地址:

  • 腾讯云云服务器(CVM):https://cloud.tencent.com/product/cvm
  • 腾讯云云数据库 MySQL 版:https://cloud.tencent.com/product/cdb_mysql
  • 腾讯云对象存储(COS):https://cloud.tencent.com/product/cos
  • 腾讯云人工智能:https://cloud.tencent.com/product/ai
  • 腾讯云物联网平台(IoT Hub):https://cloud.tencent.com/product/iothub
  • 腾讯云移动推送(TPNS):https://cloud.tencent.com/product/tpns
页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

C# 把带有父子关系数据转化为------树形结构数据 ,以及 找出父子级关系数据中里面的根数据Id

紧接上一篇,将List扁平结构数据, 转换成树形结构数据 返回给前端   ,   废话不多说,开撸! --------------------- 步骤: 1....建Tree 数据结构(用来做树形结构数据返回) public class Tree { /// /// ID //...转换后树形结构数据结果图示  -----------------------开发过程中遇到问题---------------------------------  别人博客看到这种方式,很高兴...,以为改改,很快就可以实现工作中功能,结果发现还欠缺点东西,就是要传入父节点Id值给定是0  ,写死。...而我要传入这个Id值要是动态,要根据传入List集合,找出这个集合数据里面的根节点Id值。  在这上面的代码中并没有给出, 于是我开始折腾,最终别人js 代码中找到了别人解决思路。

41120
  • 大数据技术栈之-离线数仓构建

    维度模型是直接面向业务,将业务用事实表和维度表呈现出来。表结构简单,所以查询效率高,查询简单,因为如果完全遵循3NF,就会存在大量连接查询,比较复杂,效率也不高。...比如ODS层我们保存原始数据,那么建立DWD层就是将ODS层数据作一次清洗和转换,比如去除空值数据,去除脏数据等,后面的层次再按照相应需求进行建模。...原始json数据 原始json数据如下,这就是原始数据,是一个患者简单信息,包括姓名,症状,医院这些信息,我们直接存储在HDFS。...":"1","doctor_id":1763} 创建存储原始数据hive表 建立一个hive表来存原始数据,不作任何处理,就一个json字符串,为了保证数据可溯源特性,以及后续如果数据出现问题需要重新计算数据...可以对应很多表,我们这里只简单地将这个json字符串中地字段解析出来成为一个表结构进行存储,采用医院ID和每天日期作为分区条件,数据存储格式为SNAPPY,压缩格式为orc。

    1.2K11

    Elasticsearch入门指南:构建强大搜索引擎(上篇)

    它是以JSON格式表示结构化数据对象。文档可以是任何类型数据,例如产品信息、用户记录、日志条目等。每个文档在索引中具有唯一ID,用于标识和检索它。 字段(Field):字段是文档中具体数据项。...它是以 JSON 格式表示结构化数据对象。文档可以是任何类型数据,例如产品信息、用户记录、日志条目等。 在一个索引中,每个文档都有一个唯一 ID 来标识它。...父子文档是什么 父子文档是 Elasticsearch 中一种特殊关系类型,用于表示文档之间层次结构。在父子文档关系中,每个父文档可以有多个子文档,而子文档只能有一个父文档。...映射定义: 在创建索引时,您需要定义父子关系映射定义。映射定义指定了父文档和子文档之间关系及其字段。这包括声明字段类型、索引设置和关系定义等。...相反,Elasticsearch 鼓励使用内嵌文档或嵌套对象来表示层次结构数据,以获得更好性能和查询灵活性。

    40820

    触类旁通Elasticsearch:关联

    图5 JSON层次结构,在Lucene中被存储为扁平结构 1. 映射和索引对象 默认情况下,内部对象映射是自动识别的。...routing字段向ES提供了散列ID,即路由值,这使得ES将父子文档路由到相同分片,搜索时候能从中获益。...被反规范化部分(也就是子文档)各方面看都是难以管理。 会多次索引这些文档,某文档在父辈中每出现一次,就会被索引一次。 更新时,必须更新这篇文档所有实例。 删除时,必须删除所有实例。...但如果会员更新频繁,父子结构性能更好,因为它们可以各自单独更新。 对于本例,假设一并搜索并获取分组和会员是很罕见行为,而会员经常会加入或者退出分组,因此选择父子关系。...为同一会员使用同样_id,对于会员所属分组每组使用一次。这样通过会员ID,快速并可靠地检索某位会员全部实例。

    6.3K20

    一起学Elasticsearch系列 -Nested & Join

    ES Nested 类型用于处理在一个文档中嵌套复杂结构数据,而 Join 类型用于建立父子文档之间关联关系。...解决方法可以使用Nested类型,Nested属于object类型一种,是Elasticsearch中用于复杂类型对象数组索引操作,嵌套类型(Nested)允许在一个文档内部嵌套另一个文档,这使得可以在同一个文档中表示复杂层次结构数据...父子级关系:Join 连接数据类型是一个特殊字段,它在同一索引文档中创建父/子关系。关系部分在文档中定义了一组可能关系,每个关系是一个父名和一个子名。...Global Ordinals是一种用于优化字段查询性能技术。在使用Join类型时,如果启用了Global Ordinals特性,它将为Join字段创建全局有序编号,以支持快速父子文档查询。...您可以指定要匹配父文档或子文档类型以及具体查询条件。 parent_id:用于指定要查询子文档父文档ID。通过指定parent_id参数,您可以快速检索与特定父文档相关联所有子文档。

    40610

    Spring BeanDefinition 也分父子

    BeanDefinition parentName 属性主要功能是允许我们在创建一个 bean 同时,能够继承另一个已经定义好 bean。...这样,我们只需在基础 bean 中定义一次配置,而不必为每个派生 bean 重复相同配置。 另一个使用 parentName 属性场景是在多个层次结构中定义 bean。...这种层次结构定义使得我们可以更好地组织和管理不同模块之间 bean。 通过使用 parentName 属性,我们可以轻松地创建和管理 bean 层次结构。...通过继承已有 bean 配置,我们可以避免重复编写相似的配置,并更好地组织和管理不同层次结构 bean。...范围和应用:Java 中继承主要用于类继承关系,用于定义类之间层次结构和代码重用。

    17820

    前端学习笔记—JavaScript和jQuery

    每定义一个函数就是实例化创建了一个Function函数对象,函数名就是这个对象实例名引用。...通过DOM对象接口,js可以在任何时候访问HTML文档中任何数据,利用DOM接口可以无限制控制HTML页面,可以动态创建文档,遍历文档结构,对页面结构元素进行增、删、改等操作,改变文档显示方式等...对象 jQuery 基本选择器 ("#pop") 选取id名为pop元素。...层次选择器通过 DOM 元素间层次关系获取元素,其主要层次关系包含后代、父子、相邻、兄弟关系,通过其中某类关系可方便快捷地定位元素。...需要注意是 ancestor descendant与 parent>child 选择元素集合是不同,前者层次关系是且先与后代,而后者是父子关系;另外prev+next可以使用.next0)函数代替

    12910

    树形结构数据库表设计

    第一次看见这种表结构,相信大部分人都不清楚左值(Lft)和右值(Rgt)是如何计算出来,而且这种表设计似乎并没有保存父子节点继承关系。但当你用手指指着表中数字1数到18,你应该会发现点什么吧。...第一次看见这种表结构,相信大部分人都不清楚左值(Lft)和右值(Rgt)是如何计算出来,而且这种表设计似乎并没有保存父子节点继承关系。但当你用手指指着表中数字1数到18,你应该会发现点什么吧。...,我们创建一个视图,添加了新记录节点层次数列: [sql] view plain copy CREATE VIEW dbo.TreeView AS SELECT Node_id,...Name, Lft, Rgt, dbo.CountLayer(Node_id) AS Layer FROM dbo.Tree ORDER BY Lft GO 创建存储过程,用于计算给定节点所有子孙节点及相应层次...在以查询为主绝大多数基于数据库应用系统中,该方案相比传统父子继承关系构建数据库Schema更为适用。

    2.5K20

    如何在 ES 中实现嵌套json对象查询,一次讲明白!

    原来 ES 对于json对象数组做了压扁处理,比如上面的例子在 ES 存储结构是这样: { "orderId": [ 1 ], "orderItems.productName":["火腿肠...可以看到嵌套文档方案其实是对普通内部对象方案补充。我们将上面的订单索引结构orderItems数据类型,将其改成nested类型,重新创建索引。...2.3、父子文档 我们还是看上面那个例子,假如我需要更新文档orderNo属性值,ES 对于文档更新,操作原理是:把原来数据删掉,再重新插入一条,但索引 id 是相同。...还有就是如果某个表跟某个表有多对多关系,比如一个子文档可以属于多个主文档场景,用nested无法实现,此时可以考虑采用父子文档结构来处理。...上新增关系 父子文档,适合那种数据结构基本一致场景,如果两个表结构完全不一致,不建议使用这种结构 父子文档也有缺点,查询速度是这三个方案里面最慢一个 三、小结 整体总结下来,嵌套对象通过冗余数据来提高查询性能

    8.5K50

    初识Linux下进程

    系统调用获得父子进程id   上次我们说,pid是每个进程特有的一个编号,每个进程都有自己pid,这也是进程一个属性信息,属于 操作系统内核数据结构, 我们知道,内核数据结构是不能被用户直接拿来使用...我们前面说过,进程 = 内核数据结构 + 可执行程序代码和数据,而子进程能够执行父进程代码原因,是因为 子进程被创建时,是以父进程为模版。子进程复制拷贝了父进程属性字段大部分属性。...return id; }   我们在系统中执行程序,可执行程序变为进程,进程调用fork函数从而创建子进程,而fork函数内部,在return 之前,我们子进程就已经创建完毕,最后return只是id...  运行结果来看,杀死一个进程确实不会影响另一个进程,就算是亲如父子进程。   ...进程之间相互独立没有问题,当两个进程有一个需要修改原始数据时,子进程就会发生 写时拷贝( Copy-On-Write ,以后会详谈),子进程将父进程原始数据段复制下来,这样两个进程修改数据就不会影响彼此了

    8210

    《QTreeView+QAbstractItemModel自定义模型》:系列教程之三

    那么有哪些model类呢,从下图中我们可以看到 Qt中模型类层次结构 QStandardItemModel...QTreeView与TreeItem交互过程大致如下: 注意:在树中,我们一般默认认为,只有column为0单元格才能添加下级单元格,也就是说树中每一行单元格只能与Column为0单元格建立父子关系...所以我们可以简单认为树,就是一行一行单元格组成表格,只不过在每一行通过其首个单元格,建立了父子关系。...此处我们一个TreeItem代表一行若干单元格,我们需要将多个TreeItem建立父子关系,就能够正确表示出树显示所需数据结构。...而TreeItem数据是其他地方获取来,所以我们先定义树中显示原始数据结构,如下: // person信息 typedef struct Person_t{ QString name

    5.6K10

    Elasticsearch中父子文档关联:利用Join类型赋予文档层级关系

    Nested类型和父子类型差异 Nested类型: 数据结构:Nested类型用于索引和查询对象数组,其中每个对象都可以看作是一个独立文档。...更新限制:更新Nested类型中一个嵌套对象通常需要重新索引整个主文档,这可能会影响性能。 父子类型: 数据结构父子Join类型允许你将两个独立文档(父文档和子文档)通过关系字段连接起来。...一、使用对象数组存在问题 对象数组默认存储方式: Elasticsearch内部并不直接支持对象层次结构,而是将对象层次结构扁平化为一个字段名和字段值简单列表。...三、父子join关联使用 3.1 创建带join字段索引 创建一个新索引,并定义好父子文档映射关系。在映射中加入join字段,并设置好父子关系名称。...结语 Elasticsearch中父子索引类型join是一个强大工具,它允许我们在同一索引中创建具有层级关系文档。

    35710

    将有父子关系数组对象转换成树形结构数据

    name: '3-1', 42 parentId: 7 43 } 44 ] 转换方法: 1 /** 2 * 该方法用于将有父子关系数组转换成树形结构数组 3 * 接收一个具有父子关系数组作为参数...4 * 返回一个树形结构数组 5 */ 6 translateDataToTree(data) { 7 // 没有父节点数据 8 let parents = data.filter...22 if (current.parentId === parent.id) { 23 // 对子节点数据进行深复制,这里只支持部分类型数据深复制...,对深复制不了解童靴可以先去了解下深复制 24 let temp = JSON.parse(JSON.stringify(children)) 25...// 让当前子节点temp中移除,temp作为新子节点数据,这里是为了让递归时,子节点遍历次数更少,如果父子关系层级越多,越有利 26 temp.splice

    2K20

    并行编程和任务(二)

    我们下面就看看创建任务: 我们看下创建任务几种方式: 1、使用实例化TaskFactory类,然后使用其StartNew方法启动任务。...我们看运行结果,发现首先调用TaskMethond方法时候没有任务并且使用线程1,再我们创建Task实例运行TaskMethond方法时候,任务id是1,但是线程我们依然使用是主线程1。...任务层次父子层次结构 这里我们利用任务连续性,我就就可以实现在一个任务结束后立即开启另一个任务,任务也可以构成一个层次结构。就比如一个任务中启动了一个任务,这样情况就形成了父子层次结构。...#region 任务层次结构——父子层次结构 public static void ChildTask() { Console.WriteLine...我们看下面这个案例,使用ValueTask时,在五秒内情况下直接构造函数返回值。如果时间不在五秒内的话就使用真正获取数据方法。然后我们与使用Task方法进行对比。

    66410

    【DB笔试面试478】树形查询(层次查询)可用于哪些场景?

    题目部分 树形查询(层次查询)可用于哪些场景? 答案部分 在实际开发中,如果表中数据具有逻辑上层次结构,那么可以使用层次查询以更直观地显示查询结果(包括数据本身以及数据之间层次关系)。...树形结构关系可以控制遍历树方向,是自上而下,还是自下而上,还可以确定层次开始点(ROOT)位置。...树形结构数据存放在表中,数据之间层次关系即父子关系,通过表中列与列间关系来描述,例如EMP表中EMPNO和MGR列。...6、CONNECT BY PRIOR是指定父子关系,其中,PRIOR位置不一定要在CONNECT BY之后,对于一个真实层次关系,这也是必须。...10、PRIOR运算符必须放置在连接关系两列中某一个前面。对于结点间父子关系,PRIOR运算符所在一侧表示父结点,等号另一侧表示子结点,从而确定查找树结构顺序是自顶向下还是自底向上。

    1.1K20

    以 React 方式思考

    这篇文档中,我们将通过运用React创建一个产品搜索列表,来引导你熟悉这个思考过程。 开始 假设我们已经有了一个JSON API和前端工程师设计界面,如下面这样: ?...如果它越来越大,那么它应该被分为更小部件。 由于你常常将JSON数据展示给用户看,你会发现,如果数据模型建得不错,你UI(与你部件结构)也相应不会太差。...然而,如果这个表头过于复杂(如果以后我们增加点击表头排序),当然应该作为一个独立部件ProductTableHeader来创建。 现在我们在原型中已经明确了部件,接下来把它们按照层次结构组织起来。...原型中一个部件在另一个部件中,层次结构中应该为父子层级关系: FilterableProductTable SearchBar ProductTable ProductCategoryRow ProductRow...或者说,你可以首先创建最顶层部件(例如从FilterableProductTable开始)或首先创建最底层部件(ProductRow开始)。

    3.5K30

    应聘3万职位,有必要这么刁难我么?

    而spring中父子容器就可以很好解决上面这种问题。 什么是父子容器 创建spring容器时候,可以给当前容器指定一个父容器。...BeanFactory接口,是spring容器顶层接口,这个接口中方法是支持容器嵌套结构查找,比如我们常用getBean方法,就是这个接口中定义,调用getBean方法时候,会沿着当前容器向上查找...通常我们使用springmvc时候,采用3层结构,controller层,service层,dao层;父容器中会包含dao层和service层,而子容器中包含只有controller层;这2个容器组成了父子容器关系...采用父子容器可以避免有些人在service层去注入controller层bean,导致整个依赖层次是比较混乱。...总结 本文需掌握父子容器用法,了解父子容器特点:子容器可以访问父容器中bean,父容器无法访问子容器中bean BeanFactory接口支持层次查找 ListableBeanFactory接口不支持层次查找

    52120
    领券