多表利用DIH批量导入数据并建立索引注意事项

 如果希望同时对多个表进行全文检索,那我们该如何处理呢?利用DIH导入数据并建立索引时。schema.xml中配置了uniqueKey为id

<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>
复制代码





本文转自秋楓博客园博客,原文链接:http://www.cnblogs.com/rwxwsblog/p/5053320.html,如需转载请自行联系原作者
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值