使用 DIH (DataImportHandler) 的动态列名 [英] Dynamic column names using DIH (DataImportHandler)
本文介绍了使用 DIH (DataImportHandler) 的动态列名的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
有没有办法使用返回的值创建动态列(作为键/值)名称从查询中抛出 DIH (DataImportHandler)?
Is there a way to create dynamic column (as a key/value) names using the values returned from the query throw 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>
??
推荐答案
使用 ScriptTransformer -
示例 -
数据配置 - 添加自定义字段 -
Data Config - Add custom field -
<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>
这篇关于使用 DIH (DataImportHandler) 的动态列名的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文