3

同じメッセージを jackrabbit のユーザー リストに送信しましたが、返信がありません。

ノードとその子供を Jackrabbit 2.4.3 throw jackrabbit-jcr2dav で更新したいと思います。(マージのように:ノードの更新、作成、または削除)。

しかし、リポジトリに既に存在するプロパティを更新すると、ログに ERROR が記録され、何も保存されません。これは例外ではなく、単なるエラーです。

[エラー] org.apache.jackrabbit.jcr2spi.hierarchy.ChildNodeEntriesImpl:176 - ChildInfo イテレーターに、同じ name|index または uniqueID を持つ複数のエントリーが含まれています -> ChildNodeInfo を無視します。

私のコード:

リポジトリ リポジトリ = JcrUtils.getRepository(jcrUrl); セッション session = repository.login( new SimpleCredentials("admin", "admin".toCharArray()));

    try { 
        String user = session.getUserID(); 
        String repositoryname = repository.getDescriptor(Repository.REP_NAME_DESC); 
        LOGGER.debug( "Logged in as " + user + " to a " + repositoryname + " repository.");


        // Retrieve content 
        StringBuilder expression = new StringBuilder();
        expression.append("SELECT * FROM [nt:unstructured] AS mynode ");
        expression.append("WHERE id = "+ mynode.getId() +" " );

        QueryManager queryMgr = session.getWorkspace().getQueryManager();
        Query query = queryMgr.createQuery(expression.toString(),Query.JCR_SQL2);
        QueryResult result = query.execute();
        RowIterator rowIterator = result.getRows();

        if (rowIterator.hasNext() ) {
            Node node = rowIterator.nextRow().getNode();

            // Store metadata content 
            node.setProperty("description", mynode.getDescription());
            node.setProperty("keywords", mynode.getKeywords());
            node.setProperty("title", mynode.getTitle());   // ERROR IN THE LOG AT THIS LINE because description and keywords doesn't exist, but title already exist.
            node.setProperty("resume", mynode.getResume()); 

            [... updating childs node here ]

            session.save(); 

        }
    } catch ( RepositoryException e) {
        LOGGER.error("Error getting data", e);
        throw e;
    } finally { 
        session.logout(); 
    }
    return book;
} 

誰かがすでにノード プロパティを更新しようとしていますか?

ありがとう

4

1 に答える 1