【问题标题】:How we insert 'lft' and 'rgt' values for nested-set model for a data that we are receiving from other source?我们如何为从其他来源接收的数据插入嵌套集模型的“lft”和“rgt”值?
【发布时间】:2011-05-12 15:23:45
【问题描述】:

我必须为我的 Web 应用程序管理一些分层数据。数据由四种类型的消息组成。我决定使用嵌套列表模型,因为数据中可以有任意数量的子节点。我需要存储的数据来自外部来源,如何将值添加到“lft”和“rgt”字段以将其插入 mySQL。
已编辑 这就是我显示我的应用程序使用 curl 从 Twitter 获取的消息(时间线)的方式。

foreach ($xml->entry as $status) {
       echo'<li>'.$status->content.'</li>';
   }

现在,尽管直接打印,我需要将“$status->content”的内容存储到数据库中,以便我可以操作这些内容,即在父子层次结构中打印。

【问题讨论】:

    标签: php mysql twitter datasource nested-sets


    【解决方案1】:

    一种可能性是编写递归函数或遍历要导入的数据集的过程。

    一切都取决于其他来源的结构。如果它是经典的父 id 层次结构,那么在 Java 世界中,您可以本着以下精神做一些事情:

    public class Importer {
    
        public static db = new Database();
    
        public static void processOtherSource(ArrayList<Object> data, int lft) {
            int siblings = 0;
            for (Object element : data) {
                int children = 0;
                if (element.getClass().getName().equals("ArrayList")) {
                    children = Importer.processOtherSource(element, lft+1, rgt);
                }
                int rgt = lft + children * 2 + 1;
                Importer.db.insert(element, lft, rgt);
                siblings++;
            }
            return siblings;
        }
    
        public void main(String[] args) {
            Importer.processOtherSource(dataToImport, 1);
        }
    
    }
    

    【讨论】:

    • 实际上我正在使用 php 和消息,我的应用程序使用 curl 从 Twitter 获取。我编辑了代码。
    • 我有一个问题,比如当我们从外部来源获取数据时,就像您在我的打印声明中看到的那样。 $xml 是一个包含我们需要存储的所有值的数组,所以我们不能将它视为本地输入,因为我们已经从外部源获取了所有值,这些值将在运行查询时插入到数据库中。
    • @XCeptable:嗯,我想当你下载每条推文时,你已经知道它是父母还是孩子?因为如果你这样做了,那么它归结为通过添加一个新节点来操作现有的嵌套集,这是一个微不足道的操作。
    • 不,还没有。我仍在寻找解决方案。我从 Twitter 获取的所有四种类型的推文实际上都是用户通过我的应用发送的推文,我的应用向这些推文添加了一个关键字并通过搜索将它们取回。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多