Apache Solr - Memperbarui Data
Memperbarui Dokumen Menggunakan XML
Berikut adalah file XML yang digunakan untuk memperbarui bidang di dokumen yang sudah ada. Simpan ini dalam file dengan namaupdate.xml.
<add>
<doc>
<field name = "id">001</field>
<field name = "first name" update = "set">Raj</field>
<field name = "last name" update = "add">Malhotra</field>
<field name = "phone" update = "add">9000000000</field>
<field name = "city" update = "add">Delhi</field>
</doc>
</add>
Seperti yang bisa Anda amati, file XML yang ditulis untuk memperbarui data sama seperti yang kami gunakan untuk menambahkan dokumen. Tetapi satu-satunya perbedaan adalah kami menggunakanupdate atribut lapangan.
Dalam contoh kami, kami akan menggunakan dokumen di atas dan mencoba memperbarui bidang dokumen dengan id 001.
Misalkan dokumen XML ada di bindirektori Solr. Karena kami memperbarui indeks yang ada di inti bernamamy_core, Anda dapat memperbarui menggunakan post alat sebagai berikut -
[Hadoop@localhost bin]$ ./post -c my_core update.xml
Saat menjalankan perintah di atas, Anda akan mendapatkan output berikut.
/home/Hadoop/java/bin/java -classpath /home/Hadoop/Solr/dist/Solr-core
6.2.0.jar -Dauto = yes -Dc = my_core -Ddata = files
org.apache.Solr.util.SimplePostTool update.xml
SimplePostTool version 5.0.0
Posting files to [base] url http://localhost:8983/Solr/my_core/update...
Entering auto mode. File endings considered are
xml,json,jsonl,csv,pdf,doc,docx,ppt,pptx,xls,xlsx,odt,odp,ods,ott,otp,ots,rtf,
htm,html,txt,log
POSTing file update.xml (application/xml) to [base]
1 files indexed.
COMMITting Solr index changes to http://localhost:8983/Solr/my_core/update...
Time spent: 0:00:00.159
Verifikasi
Kunjungi beranda antarmuka web Apache Solr dan pilih inti sebagai my_core. Cobalah untuk mengambil semua dokumen dengan meneruskan kueri ":" di area teksqdan jalankan kueri. Saat menjalankan, Anda dapat mengamati bahwa dokumen diperbarui.
Memperbarui Dokumen Menggunakan Java (Client API)
Berikut adalah program Java untuk menambahkan dokumen ke indeks Apache Solr. Simpan kode ini dalam file dengan namaUpdatingDocument.java.
import java.io.IOException;
import org.apache.Solr.client.Solrj.SolrClient;
import org.apache.Solr.client.Solrj.SolrServerException;
import org.apache.Solr.client.Solrj.impl.HttpSolrClient;
import org.apache.Solr.client.Solrj.request.UpdateRequest;
import org.apache.Solr.client.Solrj.response.UpdateResponse;
import org.apache.Solr.common.SolrInputDocument;
public class UpdatingDocument {
public static void main(String args[]) throws SolrServerException, IOException {
//Preparing the Solr client
String urlString = "http://localhost:8983/Solr/my_core";
SolrClient Solr = new HttpSolrClient.Builder(urlString).build();
//Preparing the Solr document
SolrInputDocument doc = new SolrInputDocument();
UpdateRequest updateRequest = new UpdateRequest();
updateRequest.setAction( UpdateRequest.ACTION.COMMIT, false, false);
SolrInputDocument myDocumentInstantlycommited = new SolrInputDocument();
myDocumentInstantlycommited.addField("id", "002");
myDocumentInstantlycommited.addField("name", "Rahman");
myDocumentInstantlycommited.addField("age","27");
myDocumentInstantlycommited.addField("addr","hyderabad");
updateRequest.add( myDocumentInstantlycommited);
UpdateResponse rsp = updateRequest.process(Solr);
System.out.println("Documents Updated");
}
}
Kompilasi kode di atas dengan menjalankan perintah berikut di terminal -
[Hadoop@localhost bin]$ javac UpdatingDocument
[Hadoop@localhost bin]$ java UpdatingDocument
Saat menjalankan perintah di atas, Anda akan mendapatkan output berikut.
Documents updated