list1234 发表于 2016-12-16 07:02:27

使用xml更新solr索引


使用xml更新solr索引


Solr接受xml格式数据更新、提交、修改索引。
 


更新的Schema


不要混淆SCHEMA.XML
add/replace documents
 
Simple Example:

<!---->·         <!----><add>
<!---->·         <!---->  <doc>
<!---->·         <!---->    <field name="employeeId">05991</field>
<!---->·         <!---->    <field name="office">Bridgewater</field>
<!---->·         <!---->    <field name="skills">Perl</field>
<!---->·         <!---->    <field name="skills">Java</field>
<!---->·         <!---->  </doc>
<!---->·         <!---->  [<doc> ... </doc>[<doc> ... </doc>]]



</add>
注:多个文件,可以在一个单一的<add>命令指定。
optional属性为“add”
overwrite =“true”|“false” 默认是“true”,意味着新的文件具有相同的uniquekey取代以前添加的文件。
 
可选的属性“DOC”
boost = <float> — default is 1.0
这是一个方便的机制◦等同的刺激属性指定各个领域,支持规范(见下文)
optional属性为“field”
update = "add" | "set" | "inc"
boost = <float> — default is 1.0
◦NOTE: 确保规范启用 (omitNorms="false" in the schema.xml)
添加各种可选的属性文件的例子
Example of "add" with optional boost attribute:

<!---->·         <!----><add>
<!---->·         <!---->  <doc boost="2.5">
<!---->·         <!---->    <field name="employeeId">05991</field>
<!---->·         <!---->    <field name="office" boost="2.0">Bridgewater</field>
<!---->·         <!---->  </doc>



</add>
 
 
Example of "add" with optional update attribute:
 

<!---->·         <!----><add>
<!---->·         <!---->  <doc>
<!---->·         <!---->    <field name="employeeId">05991</field>
<!---->·         <!---->    <field name="office" update="set">Walla Walla</field>
<!---->·         <!---->    <field name="skills" update="add">Python</field>
<!---->·         <!---->  </doc>



</add>
 
 
Example of "add" with optional update attribute to set multiple values on a multi-valued field:

<!---->·         <!----><add>
<!---->·         <!---->  <doc>
<!---->·         <!---->    <field name="employeeId">05991</field>
<!---->·         <!---->    <field name="skills" update="set">Python</field>
<!---->·         <!---->    <field name="skills" update="set">Java</field>
<!---->·         <!---->    <field name="skills" update="set">Jython</field>
<!---->·         <!---->  </doc>



</add>
 
Example of "add" with optional update attribute to set a field to null (i.e. delete a field):
 

<!---->·         <!----><add>
<!---->·         <!---->  <doc>
<!---->·         <!---->    <field name="employeeId">05991</field>
<!---->·         <!---->    <field name="skills" update="set" null="true" />
<!---->·         <!---->  </doc>
<!---->·         <!----></add>


 
"commit" and "optimize"
 
提交操作将会在新的查询请求中提现。
 
Optional attributes for "commit" and "optimize"
waitFlush = "true" | "false" — default is true,等到索引更改刷新到磁盘
waitSearcher = "true" | "false" — default is true 等到新搜索打开注册主查询搜索,使变化可见
softCommit = "true" | "false" — default is false 执行一个软的提交,这将在一个更高效的方式刷新索引的“视图”,但是没有“磁盘”的保证。
 
Optional attributes for "commit"
expungeDeletes = "true" | "false" — default is false 合并段删除掉
 
Optional attributes for "optimize"

<!---->·         <!----><commit waitSearcher="false"/>
<!---->·         <!----><commit waitSearcher="false" expungeDeletes="true"/>



<!---->·         <!----><optimize waitSearcher="false"/>

<!---->·         <!----> 



 
通过提交和commitwithin参数作为URL的一部分
curl http://localhost:8983/solr/update?commit=true -H "Content-Type: text/xml" --data-binary '<add><doc><field name="id">testdoc</field></doc></add>'
 

"delete" documents by ID and by Query

<!---->·         <!----><delete><id>05991</id></delete>



<delete><query>office:Bridgewater</query></delete>
 

<!---->·         <!----><delete>
<!---->·         <!---->  <id>05991</id><id>06000</id>
<!---->·         <!---->  <query>office:Bridgewater</query>
<!---->·         <!---->  <query>office:Osaka</query>



</delete>
参考网址
http://wiki.apache.org/solr/UpdateXmlMessages
 
页: [1]
查看完整版本: 使用xml更新solr索引