- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
我有一种轻微的感觉,我错过了明显的,但似乎无法弄清楚这一点。我正在将一个 API 从传统的 MySQL 数据模型迁移到 Cloud Datastore,并且在使用 Go Library 过滤子实体时递归构建层次结构树时遇到问题.
我的模型看起来像这样:
type Country struct {
Key *datastore.Key `datastore:"__key__"`
Id int
Name string
Region []Region
}
type Region struct {
Key *datastore.Key `datastore:"__key__"`
Id int
Name string
State []State
}
type State struct {
Key *datastore.Key `datastore:"__key__"`
Id int
Name string
}
我没有像上面的表示那样在数据存储中使用嵌套实体。在数据存储中,我有 3 个不同的实体存储每个实体及其各自的祖先 key :
Entity Country: Parent = nil
Entity Region: Parent = Country
Entity State: Parent = Region
我想查询给定的状态列表,并在结构中构建整个层次结构的正确表示。我可以实现这一点,首先检索满足我的标准的所有国家实体:
var state []*State
query := datastore.NewQuery("State").Filter("Name=", params[i])
if _, err = client.GetAll(ctx, query, &state); err != nil {
return nil, err
}
然后遍历状态以查找每个状态所属的区域:
var region Region
if err := client.Get(ctx, state[i].Key.Parent, ®ion); err != nil {
return nil, err
}
此解决方案的问题在于,返回的多个状态可能属于同一区域,如果我获得每个状态的父区域,我最终会得到一片区域,这些区域可能在它每个都有一个状态。
我知道我可以通过我的代码排序和检查是否已经添加了一个区域来解决这个问题,然后将状态附加到它上面。然而,这个解决方案似乎是解决这个问题的一种非常麻烦的方法,我想知道我是否有其他选择。
请注意,此模型只是真实模型的简化表示。真实模型在层次结构中有 9 个级别,用户可以搜索到最低级别,并且需要在最终的 JSON 中表示相应的树。
最佳答案
我不完全确定你在做什么。但是,听起来您应该在父项的 key 中对父项的名称进行编码。这样您就可以显示您需要的部分层次结构而无需获取父实体。例如。完整的子 key 可能类似于“(国家,美国),(地区,中西部),(州,密歇根)”。
如果这不起作用,我认为您应该遵循最初的想法,将要提取的父键放在一个集合中,然后一次提取所有父键。
关于谷歌云数据存储层次结构树过滤子与 Go,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55086374/
我正在尝试将多个水平链接的 Button 和 TextView 垂直链接为 View 集,但仍保持平面 View 层次结构。这是我的初始布局和代码:
到目前为止,我已经在Google BigQuery上训练了几种模型,目前我需要查看模型的外观(即架构,损失函数等)。 有没有办法获取这些信息? 最佳答案 仔细阅读文档后,我可以说该功能尚不存在。我什至
本文实例讲述了PHP实现二叉树深度优先遍历(前序、中序、后序)和广度优先遍历(层次)。分享给大家供大家参考,具体如下: 前言: 深度优先遍历:对每一个可能的分支路径深入到不能再深入为止,而且每个
我是一名优秀的程序员,十分优秀!