使用netstat -lntp来看看有侦听在网络某端口的进程。当然,也可以使用 lsof。

ES 的ES_HEAP_SIZE在windows要怎么设置

Elasticsearchmedcl 回复了问题 • 2 人关注 • 1 个回复 • 5529 次浏览 • 2017-03-25 10:57 • 来自相关话题

elasticsearch-query-tookit一款基于SQL查询elasticsearch编程工具包,支持SQL解析生成DSL,支持JDBC驱动,支持和Spring、MyBatis集成

Elasticsearchchennanlcy 发表了文章 • 1 个评论 • 9784 次浏览 • 2017-03-24 23:09 • 来自相关话题

`elasticsearch-query-tookit`是一款基于SQL查询elasticsearch编程工具包,支持SQL解析生成DSL,支持JDBC驱动,支持和Spring、MyBatis集成,提供Java编程接口可基于此工具包二次开发
 
只是重新造了个轮子,有兴趣的同学可以相互交流,QQ: 465360798
 
项目地址:https://github.com/gitchennan/ ... olkit
 
一、SQL解析生成DSL使用示例
SQL语法帮助手册戳这里: https://github.com/gitchennan/ ... p-doc
 
String sql = "select * from index.order where status='SUCCESS' and price > 100 order by nvl(pride, 0) asc routing by 'JD' limit 0, 20";

ElasticSql2DslParser sql2DslParser = new ElasticSql2DslParser();
//解析SQL
ElasticSqlParseResult parseResult = sql2DslParser.parse(sql);
//生成DSL(可用于rest api调用)
String dsl = parseResult.toDsl();

//toRequest方法接收一个clinet对象参数
SearchRequestBuilder searchReq = parseResult.toRequest(esClient);
//执行查询
SearchResponse response = searchReq.execute().actionGet();
生成的DSL如下:
{
"from" : 0,
"size" : 20,
"query" : {
"bool" : {
"filter" : {
"bool" : {
"must" : [ {
"term" : {
"status" : "SUCCESS"
}
}, {
"range" : {
"price" : {
"from" : 100,
"to" : null,
"include_lower" : false,
"include_upper" : true
}
}
} ]
}
}
}
},
"sort" : [ {
"pride" : {
"order" : "asc",
"missing" : 0
}
} ]
}
二、集成MyBatis、Spring
 
首先在Spring配置文件中增加如下代码
1. 指定driverClassName:org.elasticsearch.jdbc.api.ElasticDriver
2. 指定连接ES的连接串:jdbc:elastic:192.168.0.109:9300/product_cluster
3. 创建一个SqlMapClient对象,并指定sqlMapConfig.xml路径
 
<bean id="elasticDataSource" class="org.elasticsearch.jdbc.api.ElasticSingleConnectionDataSource" destroy-method="destroy">
<property name="driverClassName" value="org.elasticsearch.jdbc.api.ElasticDriver" />
<property name="url" value="jdbc:elastic:192.168.0.109:9300/product_cluster" />
</bean>

<bean id="sqlMapClient" class="org.springframework.orm.ibatis.SqlMapClientFactoryBean">
<property name="dataSource" ref="elasticDataSource" />
<property name="configLocation" value="classpath:sqlMapConfig.xml"/>
</bean>
sqlMapConfig.xml文件内容如下:
<sqlMapConfig>
<settings
cacheModelsEnabled="true"
lazyLoadingEnabled="true"
enhancementEnabled="true"
maxSessions="64"
maxTransactions="20"
maxRequests="128"
useStatementNamespaces="true"/>

<sqlMap resource="sqlmap/PRODUCT.xml"/>

</sqlMapConfig>
PRODUCT.xml文件中声明select sql语句
<sqlMap namespace="PRODUCT">
<select id="getProductByCodeAndMatchWord" parameterClass="java.util.Map" resultClass="java.lang.String">
SELECT *
FROM index.product
QUERY match(productName, #matchWord#) or prefix(productName, #prefixWord#, 'boost:2.0f')
WHERE productCode = #productCode#
AND advicePrice > #advicePrice#
AND $$buyers.buyerName IN ('china', 'usa')
ROUTING BY #routingVal#
</select>
</sqlMap>
编写对应DAO代码:
@Repository
public class ProductDao {
@Autowired
@Qualifier("sqlMapClient")
private SqlMapClient sqlMapClient;


public List<Product> getProductByCodeAndMatchWord(String matchWord, String productCode) throws SQLException {
Map<String, Object> paramMap = Maps.newHashMap();
paramMap.put("productCode", productCode);
paramMap.put("advicePrice", 1000);
paramMap.put("routingVal", "A");
paramMap.put("matchWord", matchWord);
paramMap.put("prefixWord", matchWord);
String responseGson = (String) sqlMapClient.queryForObject("PRODUCT.getProductByCodeAndMatchWord", paramMap);

//反序列化查询结果
JdbcSearchResponseResolver responseResolver = new JdbcSearchResponseResolver(responseGson);
JdbcSearchResponse<Product> searchResponse = responseResolver.resolveSearchResponse(Product.class);

return searchResponse.getDocList();

}
}
编写测试方法
@Test
public void testProductQuery() throws Exception {
BeanFactory factory = new ClassPathXmlApplicationContext("application-context.xml");
ProductDao productDao = factory.getBean(ProductDao.class);

List<Product> productList = productDao.getProductByCodeAndMatchWord("iphone 6s", "IP_6S");
for (Product product : productList) {
System.out.println(product.getProductName());
}
}

 
 

es存储时文件名异常

Elasticsearchmedcl 回复了问题 • 2 人关注 • 1 个回复 • 4558 次浏览 • 2017-03-24 19:53 • 来自相关话题

你好,我发了一个问题,能帮忙看看嘛(链接:http://elasticsearch.cn/question/1349),多谢~~~

回复

Elasticsearchhellosearch 发起了问题 • 1 人关注 • 0 个回复 • 4402 次浏览 • 2017-03-24 17:34 • 来自相关话题

拼音分词问题

Elasticsearchhellosearch 回复了问题 • 4 人关注 • 2 个回复 • 7350 次浏览 • 2017-03-27 17:45 • 来自相关话题

写了几篇ElasticSearch入门的文章分享一下

Elasticsearchkilik52 发表了文章 • 1 个评论 • 4237 次浏览 • 2017-03-24 16:08 • 来自相关话题

我把自己建立一个简单的中文搜索引擎的过程写成了几篇博客。在这里和大家分享一下:
 
轻轻松松做个强大的搜索引擎01 -- 数据库安装:
https://www.zhuxichi.com/2017/ ... al01/
 
轻轻松松做个强大的搜索引擎02 -- 数据录入:
https://www.zhuxichi.com/2017/ ... al02/
 
轻轻松松做个强大的搜索引擎03 -- 全文搜索:
https://www.zhuxichi.com/2017/ ... al03/
 
轻轻松松做个强大的搜索引擎04 -- 分词:
https://www.zhuxichi.com/2017/ ... al04/
 
轻轻松松做个强大的搜索引擎05 -- 关键词高亮:
https://www.zhuxichi.com/2017/ ... al05/
 
轻轻松松做个强大的搜索引擎06 -- 搜索词建议:
https://www.zhuxichi.com/2017/ ... al06/
 
轻轻松松做个强大的搜索引擎07 -- Boosting:
https://www.zhuxichi.com/2017/ ... al07/
 
欢迎交流哈

es5.2.2 client node问题。

Elasticsearchkennywu76 回复了问题 • 6 人关注 • 2 个回复 • 4512 次浏览 • 2017-03-25 12:35 • 来自相关话题

elasticsearch关联查询

Elasticsearchxiongchaochao 回复了问题 • 6 人关注 • 3 个回复 • 8959 次浏览 • 2019-05-07 17:05 • 来自相关话题

msearch 搜索只返回一个结果

Elasticsearchmedcl 回复了问题 • 1 人关注 • 1 个回复 • 5087 次浏览 • 2017-03-25 10:37 • 来自相关话题

es 集群规划的问题

Elasticsearchkennywu76 回复了问题 • 11 人关注 • 1 个回复 • 6548 次浏览 • 2017-03-23 18:36 • 来自相关话题

ES扩容机器磁盘不够,增加节点的问题

Elasticsearchkennywu76 回复了问题 • 3 人关注 • 1 个回复 • 11416 次浏览 • 2017-03-23 18:47 • 来自相关话题

ElasticSearch 打开 translog 文件句柄过多

Elasticsearchxiangxji 回复了问题 • 3 人关注 • 3 个回复 • 6649 次浏览 • 2017-03-23 21:16 • 来自相关话题

ES 分词精确查询问题

Elasticsearchmedcl 回复了问题 • 2 人关注 • 1 个回复 • 5467 次浏览 • 2017-03-25 14:30 • 来自相关话题

不同分类中同一属性的联合sort排序问题

Elasticsearchmedcl 回复了问题 • 2 人关注 • 1 个回复 • 3968 次浏览 • 2017-03-25 14:31 • 来自相关话题

es5.2.2的java技术选型问题

Elasticsearchmedcl 回复了问题 • 2 人关注 • 1 个回复 • 6101 次浏览 • 2017-03-25 10:26 • 来自相关话题