使用DIH的动态列名称(DataImportHandler)

时间:2011-10-27 14:21:40

标签: search solr lucene

有没有办法使用返回的值创建动态列(作为键/值)名称 从查询中抛出DIH(DataImportHandler)?

例如:

<entity name="foo" dataSource="my_database" query="select key,value from foo where id=${item.id}">
   <field column="${foo.key}" value="${foo.value}" name="${foo.key}_s"/>
</entity>

...

1 个答案:

答案 0 :(得分:8)

使用ScriptTransformer -

示例 -

数据配置 - 添加自定义字段 -

<script><![CDATA[
        function addfield(row){
            var fieldName = row.get('key') + "_s"
            row.put(fieldName, row.get('value'));
            return row;
        }
]]></script>

实体映射 -

<entity name="foo" dataSource="my_database" transformer="script:addfield" query="select key,value from foo where id=${item.id}">
    ......
</entity>