Elasticsearch 插入索引文档 和特殊的字段类型

1、创建索引时,如果es的字段类型和java的字段类型相对应的,可以不用创建这个这个字段,在插入记录的时候,es会自动帮你创建

2、转载 ,插入经纬度的时候,http://www.cnblogs.com/youran-he/articles/7435476.html

Elasticsearch在插入文档数据的时候,Elasticsearch新增了一些java对象没有的数据类型。当从数据库中读取数据的时候如果与Elasticsearch的数据类型相同,则默认不需要创建maping,Elasticsearch手动导入数据的时候自动创建相应的map;因此,需要转换成json格式传到es之后才能创建:代码如下:

    try {
            Bulk.Builder bulk = new Bulk.Builder().defaultIndex(indexname).defaultType(type);
//            String json = "{"+"\"location\":"+"["+location.getLongitude()+","+location.getLatitude()+"]}";
            String json = "{"+"\"location\":"+"\""+location.getLatitude()+","+location.getLongitude()+"\""+","+"\"id\":"+"\"1234546\""+"}";
            System.out.println(json);
            Index index = new Index.Builder(json).build();
            bulk.addAction(index);
            BulkResult br = client.execute(bulk.build());
            return br.isSucceeded();
        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
            return false;
        }

折腾一个下午,终于出结果啦!激动一下啊




猜你喜欢

转载自blog.csdn.net/haiyang4988/article/details/77603156