elasticsearch 데이터 가져오기 내보내기
try {
// ES
BufferedReader br = new BufferedReader(new FileReader("D:/item6.json"));
String json = null;
int count = 0;
//
BulkRequestBuilder bulkRequest = client.prepareBulk();
while ((json = br.readLine()) != null) {
//setId index _Id , ,es id,
bulkRequest.add(client.prepareIndex("6", "item6").setId("0000"+count).setSource(json));
// 100
if (count% 100==0) {
bulkRequest.execute().actionGet();
System.out.println(" :" + count);
}
count++;
}
bulkRequest.execute().actionGet();
System.out.println(" ");
br.close();
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
json 데이터는 한 줄에 데이터를 놓아야 합니다. 나비캣 도구를 사용하여 mysql에서 조회 결과를 내보낸 다음 ue 편집기를 사용하여 형식 교체 처리를 할 수 있습니다. 다음과 같습니다.
{'item_name':'gugu','brand_name':'시멘스','c_name':'웹캠'} {'item_name':'소니(SONY) HDR-PJ670 HD 디지털 카메라','brand_name':'시멘스','c_name':'웹캠'} {'item_name':'llb1008 테스트 상품','brand_name':'Netskys','c_name':'안방'}
2, elasticsearch는 json 형식의 데이터를 내보냅니다. 코드는 다음과 같습니다.
SearchResponse response = client.prepareSearch("6").setTypes("item6")
.setQuery(QueryBuilders.matchAllQuery()).setSize(10000).setScroll(new TimeValue(600000))
.setSearchType(SearchType.SCAN).execute().actionGet();
String scrollid = response.getScrollId();
try {
// JSON
BufferedWriter out = new BufferedWriter(new FileWriter("D:/item6_export.json", true));
// 10000 。
while (true) {
SearchResponse response2 = client.prepareSearchScroll(scrollid).setScroll(new TimeValue(1000000)).execute().actionGet();
SearchHits searchHit = response2.getHits();
//
if (searchHit.getHits().length == 0) {
break;
}
System.out.println(" :" + searchHit.getHits().length);
for (int i = 0; i < searchHit.getHits().length; i++) {
String json = searchHit.getHits()[i].getSourceAsString();
out.write(json);
out.write("\r
");
}
}
System.out.println(" ");
out.close();
} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.