多表利用DIH批量导入数据并建立索引注意事项
2015-12-17 19:42
417 查看
如果希望同时对多个表进行全文检索,那我们该如何处理呢?利用DIH导入数据并建立索引时。schema.xml中配置了uniqueKey为id
如果多表主键都为id的话索引会被覆盖
由于id是唯一键,如果id重复索引会被覆盖掉。此时可以加个简易的标识,以便构造不同表的uniqueKey
修改后配置文件
<uniqueKey>id</uniqueKey>
如果多表主键都为id的话索引会被覆盖
<!--deltaImportQuery和deltaQuery为增量导入时使用。--> <entity name="case" pk="id" query="SELECT id,title, summary, 'case' as type FROM case" deltaImportQuery="SELECT id, title, summary, 'case' as type from case WHERE id='${dih.delta.id}'" deltaQuery="SELECT id, title, summary, 'case' as type FROM case WHERE create_time > '${dih.last_index_time}'" > <!--field用于配置schema.xml中field和数据库字段的对应关系。column:数据库中字段名称,name:schema.xml中配置的名称--> <field column="id" name="id"/> <field column="title" name="title"/> <field column="summary" name="summary"/> </entity> <!--deltaImportQuery和deltaQuery为增量导入时使用。--> <entity name="casetest" pk="id" query="SELECT id,title, summary, 'case_test' as type FROM casetest" deltaImportQuery="SELECT id, title, summary, 'case_test' as type from casetest WHERE id='${dih.delta.id}'" deltaQuery="SELECT id, title, summary, 'case_test' as type FROM casetest WHERE create_time > '${dih.last_index_time}'" > <!--field用于配置schema.xml中field和数据库字段的对应关系。column:数据库中字段名称,name:schema.xml中配置的名称--> <field column="id" name="id"/> <field column="title" name="title"/> <field column="summary" name="summary"/> <field column="type" name="type"/> </entity>
由于id是唯一键,如果id重复索引会被覆盖掉。此时可以加个简易的标识,以便构造不同表的uniqueKey
修改后配置文件
<!--deltaImportQuery和deltaQuery为增量导入时使用。--> <entity name="case" pk="id" query="SELECT concat('case_Type_', id) as id,title, summary, 'case' as type FROM case" deltaImportQuery="SELECT concat('case_Type_', id) as id, title, summary, 'case' as type from case WHERE id='${dih.delta.id}'" deltaQuery="SELECT concat('case_Type_', id) as id, title, summary, 'case' as type FROM case WHERE create_time > '${dih.last_index_time}'" > <!--field用于配置schema.xml中field和数据库字段的对应关系。column:数据库中字段名称,name:schema.xml中配置的名称--> <field column="id" name="id"/> <field column="title" name="title"/> <field column="summary" name="summary"/> </entity> <!--deltaImportQuery和deltaQuery为增量导入时使用。--> <entity name="casetest" pk="id" query="SELECT concat('case_test_Type_', id) as id,title, summary, 'case_test' as type FROM casetest" deltaImportQuery="SELECT concat('case_test_Type_', id) as id, title, summary, 'case_test' as type from casetest WHERE id='${dih.delta.id}'" deltaQuery="SELECT concat('case_test_Type_', id) as id, title, summary, 'case_test' as type FROM casetest WHERE create_time > '${dih.last_index_time}'" > <!--field用于配置schema.xml中field和数据库字段的对应关系。column:数据库中字段名称,name:schema.xml中配置的名称--> <field column="id" name="id"/> <field column="title" name="title"/> <field column="summary" name="summary"/> <field column="type" name="type"/> </entity>
相关文章推荐
- Beta版本冲刺———第七天
- 3678: wangxz与OJ
- [笔记]修改mac终端命令行前缀的显示
- C++11引用限定符
- [Linux]ubuntu下共享文件夹密码设置和重置-smbpasswd -a user
- 中断
- Detours信息泄漏漏洞
- 网页去重(一)简介
- visual studio下实现图形函数调用
- 黑马程序员--Java编程之反射篇
- 如何在Allegro中添加中文汉字
- 解决在Fragment中不能自动弹出软键盘的问题
- CAAnimation动画/CAAnimation Group
- OC
- poj 1724 ROADS 最短路
- Daily Scrum 12.17
- 修改 SVN 提交 LOG 默认编辑器
- Softmax回归
- Android-->RxJava/RxAndroid 入门初体验
- k8s google sample - guestbook