栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

从Java向类型添加映射

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

从Java向类型添加映射

终于,经过一天的谷歌搜索获得了回报。坦率地说,用于Elasticsearch的Java API文档可以使用一些端到端示例,更不用说JavaDoc …

这是一个正在运行的示例。您必须在本地主机上运行一个节点,才能正常工作!

package foo;import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;import java.io.IOException;import org.elasticsearch.action.admin.indices.create.CreateIndexRequestBuilder;import org.elasticsearch.action.admin.indices.delete.DeleteIndexRequestBuilder;import org.elasticsearch.action.admin.indices.exists.indices.IndicesExistsResponse;import org.elasticsearch.action.get.GetRequestBuilder;import org.elasticsearch.action.get.GetResponse;import org.elasticsearch.action.index.IndexRequestBuilder;import org.elasticsearch.client.Client;import org.elasticsearch.client.transport.TransportClient;import org.elasticsearch.common.settings.ImmutableSettings;import org.elasticsearch.common.transport.InetSocketTransportAddress;import org.elasticsearch.common.xcontent.XContentBuilder;public class MyTestClass {    private static final String ID_NOT_FOUND = "<ID NOT FOUND>";    private static Client getClient() {        final ImmutableSettings.Builder settings = ImmutableSettings.settingsBuilder();        TransportClient transportClient = new TransportClient(settings);        transportClient = transportClient.addTransportAddress(new InetSocketTransportAddress("localhost", 9300));        return transportClient;    }    public static void main(final String[] args) throws IOException, InterruptedException {        final Client client = getClient();        // Create Index and set settings and mappings        final String indexName = "test";        final String documentType = "tweet";        final String documentId = "1";        final String fieldName = "foo";        final String value = "bar";        final IndicesExistsResponse res = client.admin().indices().prepareExists(indexName).execute().actionGet();        if (res.isExists()) { final DeleteIndexRequestBuilder delIdx = client.admin().indices().prepareDelete(indexName); delIdx.execute().actionGet();        }        final CreateIndexRequestBuilder createIndexRequestBuilder = client.admin().indices().prepareCreate(indexName);        // MAPPING GOES HERE        final XContentBuilder mappingBuilder = jsonBuilder().startObject().startObject(documentType)     .startObject("_ttl").field("enabled", "true").field("default", "1s").endObject().endObject()     .endObject();        System.out.println(mappingBuilder.string());        createIndexRequestBuilder.addMapping(documentType, mappingBuilder);        // MAPPING DONE        createIndexRequestBuilder.execute().actionGet();        // Add documents        final IndexRequestBuilder indexRequestBuilder = client.prepareIndex(indexName, documentType, documentId);        // build json object        final XContentBuilder contentBuilder = jsonBuilder().startObject().prettyPrint();        contentBuilder.field(fieldName, value);        indexRequestBuilder.setSource(contentBuilder);        indexRequestBuilder.execute().actionGet();        // Get document        System.out.println(getValue(client, indexName, documentType, documentId, fieldName));        int idx = 0;        while (true) { Thread.sleep(10000L); idx++; System.out.println(idx * 10 + " seconds passed"); final String name = getValue(client, indexName, documentType, documentId, fieldName); if (ID_NOT_FOUND.equals(name)) {     break; } else {     // Try again     System.out.println(name); }        }        System.out.println("document was garbage collected");    }    protected static String getValue(final Client client, final String indexName, final String documentType, final String documentId, final String fieldName) {        final GetRequestBuilder getRequestBuilder = client.prepareGet(indexName, documentType, documentId);        getRequestBuilder.setFields(new String[] { fieldName });        final GetResponse response2 = getRequestBuilder.execute().actionGet();        if (response2.isExists()) { final String name = response2.getField(fieldName).getValue().toString(); return name;        } else { return ID_NOT_FOUND;        }    }}


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/383372.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号