dao代码模板
es是一个近乎实时的搜索平台,这意味着从索引文档到文档可搜索,仅有一点点延迟(通常是1秒)。es集群是一个或多个节点的集合,它们共同保存数据,并提供跨所有节点的联合索引和搜索功能。集群名由cluster.name指定,每个节点名由node.name指定。
通过 get /_cat 可以找出很多实用的命令,使用这些命令时在最后加上?v可以展示数据的含义,如
get /_cat/indices?v 查看所有索引的分片数、副本数、文档数、索引大小
get /_cat/nodes?v 查看集群所有的节点,从返回的结果中可以找出哪一个节点是master
get /_cat/shards/{index}?v 查看某索引各分片文档数、分片大小、所在节点ip
还有其他很多实用的命令,不再一个个列举,用的时候从里面找即可。
Search API
根据搜索参数放的位置不同,有两种搜索方式:一种是把参数放到request uri上,另一种是使用request body
其中第一种比较少用,本文仅提供一个例子,不做详细介绍
示例:
get /bank/_doc/_search?q=*&sort=age:asc,balance:asc&from=10&size=3
第二种方式比较常用,使用起来也比较简单,把搜索参数以json格式放到请求体中
get /bank/_doc/_search
{
"query": {
"match_all": {}
},
"sort": {
"age": "asc",
"balance": "desc"
},
"from": 10,
"size": 3
}
from表示跳过几个文档,为0时表示一个都不跳过,从头开始取。
如果只想返回特定的字段,比如age、balance,则命令是
get /bank/_doc/_search
{
"query": {
"match_all": {}
},
"_source": ["balance", "age"]
}
如果想取balance=49355的文档,则要用match关键字替换match_all,命令是
get /bank/_doc/_search
{
"query": {
"match": {
"balance": "49355"
}
}
}
取address包含"mill"单词的文档,命令是
get /bank/_doc/_search
{
"query": {
"match": {
"address": "mill"
}
}
}
实际上,结果中不仅有address包含"mill"单词的文档,还有address包含“Mill”单词的文档。这是因为es在索引文档时会把所有字母都转为小写,在搜索时也会把搜索参数中的字母转为小写,这样,即使用mill或者MILL搜索,都会返回address包含"mill"、"MILL"等凡是这四个字母组成的单词的文档。
取address包含"mill"或"lane"的文档,命令是
get /bank/_doc/_search
{
"query": {
"match": {
"address": "mill lane"
}
}
}
取address包含"mill lane"短语的文档,命令是:
get /bank/_doc/_search
{
"query":{
"match_phrase": {
"address": "mill lane"
}
}
}
注意这里用了match_phrase替代之前的match,phrase的意思就是短语。
上面命令query下面一级直接是match_all、match或match_phrase,这仅适用于单条件搜索。想要多条件搜索的话,需要用bool query,表现形式是query下面一级是bool,bool下面一级是must数组或者should数组或者must_not数组,数组里面才是多个match或者match_phrse。其中must数组是既。。又。。的意思,should数组是或。。或。。的意思,must_not数组是既不。。又不。。的意思。没有shoud_not。
取address包含"mill"单词且age=28的文档,命令是
get /bank/_doc/_search
{
"query": {
"bool": {
"must": [{
"match": {
"address": "mill"
}
}, {
"match": {
"age": 38
}
}]
}
}
}
取address包含"mill"单词或者age=28的文档,命令是
get /bank/_doc/_search
{
"query": {
"bool": {
"should": [{
"match": {
"address": "mill"
}
}, {
"match": {
"age": "28"
}
}]
}
}
}
取address不包含"mill"单词且age!=28的文档,命令是
get /bank/_doc/_search
{
"query": {
"bool": {
"must_not": [{
"match": {
"address": "mill"
}
}, {
"match": {
"age": 28
}
}]
}
}
}
也可以在bool中混合使用must数组、should数组、must_not数组。注意,should数组与must数组或是must_not数组一起使用的话,必须把should数组放在must数组中,即should数组是must数组的一个元素,且should数组用bool包裹。
取age=39,且firstname是Virginia或者lastname是Ayala的文档,命令是
get /bank/_doc/_search
{
"query": {
"bool": {
"must": [{
"match": {
"age": 39
}
}, {
"bool": {
"should": [{
"match": {
"firstname": "Virginia"
}
}, {
"match": {
"lastname": "Ayala"
}
}]
}
}]
}
}
}
大于、小于的筛选搜索
bool query除了must、should、must_not外,还支持filter数组,相当于sql中的大于(等于)、小于(等于),用于数字或日期过滤。filter数组里面元素的key是range,值是个json对象,对象的key是筛选字段。
取state=MA且余额在(8000,10000)、年龄在[20,30]的文档,命令是
get /bank/_doc/_search
{
"query": {
"bool": {
"must": [{
"match": {
"state": "MA"
}
}],
"filter": [{
"range": {
"balance": {
"gt": 8000,
"lt": 10000
}
}
}, {
"range": {
"age": {
"gte": 20,
"lte": 30
}
}
}]
}
}
}
聚合
根据state字段分组,并根据文档数量大小倒序取前10,命令是
get /bank/_search
{
"size": 0,
"aggs": {
"group_by_state": {
"terms": {
"field": "state.keyword",
"size": 3
}
}
}
}
dao代码模板的更多相关文章
- 基于JEECG的代码模板自动生成
1.基于JEECG3.5.2,提供多种数据源的代码生成,目前支持Oracle良好: 2.可动态配置数据源: 可动态配置模板集合,基于freemarker的模板文件: 可选择需要生成的数据表: 可导入一 ...
- Java代码自动生成,生成前端vue+后端controller、service、dao代码,根据表名自动生成增删改查功能
本项目地址:https://github.com/OceanBBBBbb/ocean-code-generator 项目简介 ocean-code-generator采用(适用): ,并使用m ...
- SpringBoot+MyBatisPlus整合时提示:Invalid bound statement(not found):**.dao.UserDao.queryById
场景 在使用SpringBoot+MyBatisPlus搭建后台启动项目时,使用EasyCode自动生成代码. 在访问后台接口时提示: Invilid bound statement (not fou ...
- java中Action层、Service层和Dao层的功能区分
Action/Service/DAO简介: Action是管理业务(Service)调度和管理跳转的. Service是管理具体的功能的. Action只负责管理,而Service负责实施. DAO只 ...
- DAO层,Service层,Controller层、View层 的分工合作
DAO层:DAO层主要是做数据持久层的工作,负责与数据库进行联络的一些任务都封装在此,DAO层的设计首先是设计DAO的接口,然后在Spring的配置文件中定义此接口的实现类,然后就可在模块中调用此接口 ...
- 使用MyBatis Generator自动创建代码(dao,mapping,poji)
连接的数据库为SQL server2008,所以需要的文件为sqljdbc4.jar 使用的lib库有: 在lib库目录下新建一个src文件夹用来存放生成的文件,然后新建generatorConfig ...
- DAO设计模式
DAO设计模式 DAO设计模式简介: DAO设计模式可以减少代码量,增强程序的可移植性,提高代码的可读性. DAO(数据库操作对象)设计模式是 JavaEE 数据层的操作.主要由五部分组成: 1.数据 ...
- mybatis generator 自动生成dao层映射代码
资源: doc url :http://www.mybatis.org/generator/ download:https://github.com/mybatis/generator/release ...
- 010商城项目:商品类目的选择——Dao,Service.Action层的分析
我们现在开始写商品类选择这个功能: 先看效果: 当我们点击"新增商品"---->"选择目录"然后从数据库中查出来数据并显示了. 我们分析数据库的那张表: ...
随机推荐
- Ecshop出现问题 includes\lib_main.php on line 1329 includes\lib_base.php on line
php 5.3版本兼容问题不少,以上函数参数传递问题可以将lib_main.php on line 1329这句 $ext = end(explode('.', $tmp)); 改为 : $extsu ...
- GDKOI 2015 Day1 T2 单词统计Pascal
我虽然没有参加GDKOI2015,但是我找了2015年的题练了一下. 题意如下: 思路:最大流,因为有多组数据,每次读入一组数据都要清零. a. 将每个点拆分成两个点,例如样例G→G`,再将字母一一编 ...
- JS 处理十六进制颜色渐变算法-输入颜色,输出渐变rgb数组
html颜色有几种表示方式: 英文单词颜色值:background-color:Blue:十六进制颜色值:background-color:#FFFFFF: RGB颜色值三元数字:backgroun ...
- 【CSS学习笔记】关于有语义标签
1.哪些是单闭合标签,哪些是双闭合标签? HTML的单闭合标签有: 1.<br /> 2.<hr /> 3.<area /> 4.<base /> 5. ...
- SSH 一些错误的解决办法
1.主动访问的机器需要创建私钥和公钥 (client) #cd ~#mkdir .ssh#chmod 700 .ssh#cd .ssh#ssh-keygen -t rsa //一路回车,各种提示按默认 ...
- Notepad++中调试用心lua程序
一.配置: 1.打开Notepad++: 2. 按下F5,或者打开Run->Run… 3. 弹出Run的窗口 3. 这一步是最关键的,将下列语句拷贝粘贴至输入框中:cmd /k Python & ...
- Kafka集群搭建
1.zookeeper搭建 Kafka集群依赖zookeeper,需要提前搭建好zookeeper zookeeper快速搭建推荐地址:http://nileader.blog.51cto.com/1 ...
- Hololens生成与安装(旁加载)应用
Hololens生成应用的几种方式: 一:HoloToolkit编辑器生成appx应用 二:Vistul Studio 2015 创建应用 旁加载概述: 你可以将应用旁加载到你的设备,而无需将它们提交 ...
- for for-in foreach 循环
var a = [1, 2, 3, 4, 5] //for用来便利数组元素非常简单 for (var i = 0; i < a.length; i++) { console.log(a[i]) ...
- python3 验证用户名密码
输入用户名,密码,匹配通过,不匹配报错 import getpass user = input('input username: ') pwd = getpass.getpass('input pas ...