一阵子不用es又忘光光了,犯了个极其弱智的错误。。。
想查询name是shuai的记录,于是写下了下面这个语句:
curl -X POST --header “Content-Type: application/json” http://127.0.0.1:9200/aaa/aaa/_search -d “{“query”: {“term”: {“name”: “shuai”}}}”
执行后报错:
{“error”:{“root_cause”:[{“type”:“json_parse_exception”,“reason”:“Unexpected character (‘q’ (code 113)): was expecting double-quote to start field name\n at [Source: org.elasticsearch.transport.netty4.ByteBufStreamInput@16e75957; line: 1, column: 3]”}],“type”:“json_parse_exception”,“reason”:“Unexpected character (‘q’ (code 113)): was expecting double-quote to start field name\n at [Source: org.elasticsearch.transport.netty4.ByteBufStreamInput@16e75957; line: 1, column: 3]”},“status”:500}
晃眼一看以为是json格式错误,检查了好几遍json也没找到哪里格式错了
最后仔细一看才反应过来,原来是
json里的双引号没转义
。。。
修改后如下:
curl -X POST --header “Content-Type: application/json” http://127.0.0.1:9200/aaa/aaa/_search -d “{“query”: {“term”: {“name”: “shuai”}}}”
执行返回成功
或者利用
单引号里的内容不转义
的特性:json的最外层用单引号,其余双引号
curl -X POST --header “Content-Type: application/json” http://127.0.0.1:9200/aaa/aaa/_search -d ‘{“query”: {“term”: {“name”: “shuai”}}}’
参考链接:
https://blog.miuyun.work/archives/13100849
es --- Unexpected character (‘q‘ (code 113)): was expecting double-quote to start field name\n
一阵子不用es又忘光光了,犯了个极其弱智的错误。。。 想查询name是shuai的记录,于是写下了下面这个语句:curl -X POST --header “Content-Type: application/json” http://127.0.0.1:9200/aaa/aaa/_search -d “{“query”: {“term”: {“name”: “shuai”}}}”执行后报错:{“error”:{“root_cause”:[{“type”:“
elasticsearch在window中报错:"
Unexpected
character
('m' (
code
109)): was
expecting
double-quote
to
start
elasticsearch从入坑到放弃
今天在配置问答系统中使用到了elasticsearch,由于在Linux下开发界面不友好,就直接在Windows下配置环境进行开发,结果一不小心入了一个坑,折腾了三个多小时才弄出来,所以以后还是要用Linux开发。。。
从官网下载
ES
https://www.elastic.co/guide/en/elasticsearch/reference/curr...
报错:JSON parse error:
Unexpected
character
(‘ ‘ (
code
160)): was
expecting
double-quote
to
start
fiel
使用Kibana设置索引的时候,执行语句出现错误:
Unexpected
character
(’}’ (
code
125)): was
expecting
double-quote
to
start
field
name
我按照错误不断检查双引号是否正确,结果最后找出来是逗号多了一个,晕。
一、
ES
7报错
Failed to parse mapping [_doc]: Root mapping definition has unsupported parameters
原因:
es
7不建议使用type,默认的type未doc,因此默认不支持指定type对应的mapping
解决方法:指定索引类型需修改参数include_type_name
PUT index/_mappings?include_type_name=true
(但
es
8会弃用type,因此最好不要再使用
今天在使用
ES
查询20000条数据时报错:
ERRO[0005] Search dga rul
es
failed elastic: Error 500 (Internal Server Error): all shards failed [type=search_phase_execution_exception]
随手附个代码吧,或许对有缘人有用~
searchR
es
ult,err :=
es
.
ES
Client.Search().
Index(a).Typ
### 回答1:
这是一个JSON格式错误,意思是在JSON对象中遇到了一个意外的字符 '}',但是应该是一个双引号来开始字段名。这通常是由于JSON对象中的语法错误或缺失引号导致的。需要检查JSON对象的语法并确保所有字段名都被双引号包围。
### 回答2:
这个错误提示说明在一个地方出现了一个预期之外的特殊字符 '}',而程序预期的是一个双引号来开启一个字段名。
这个错误通常发生在处理JSON格式的数据时。JSON是一种常用的数据交换格式,严格要求使用双引号来包围字段名和字符串值。如果在JSON中使用了其他字符(如单引号)来代替双引号,或者忘记包围字段名的双引号,就会导致这个错误。
解决这个问题的方法是检查代码中对JSON数据的处理部分,找到错误的特殊字符,并将其替换为双引号。同时确保所有的字段名都被双引号包围。以下是一个示例:
错误的JSON数据:{ name: 'John', age: 25 }
修正后的JSON数据:{ "name": "John", "age": 25 }
通过这样的修正,就可以避免该错误,并使代码正确地解析和处理JSON数据。
### 回答3:
这个错误信息说明在代码中出现了一个意外的字符 '}',而解析器预期的是双引号来开始字段名。这种错误通常在处理JSON格式的数据时出现。
JSON是一种用于数据交换的格式,它使用键值对的形式来组织数据。每个键值对由一个字段名和一个字段值组成,它们之间用冒号分隔。字段名和字段值都需要被双引号包围。
一个常见的问题是,当我们在代码中书写JSON数据时,忘记或者错误地添加了双引号来标记字段名。当解析器在处理这段代码时,就会遇到问题,因为它期望双引号来定义字段名。
为解决这个问题,我们需要确保所有的字段名都被双引号包围。例如,如果我们有一个字段名为 "name" 的键值对,我们需要这样书写代码: "name": "John"。注意字段名 "name" 前后都有双引号。
另外,如果我们的字段值是一个字符串,同样需要用双引号包围。如果字段值是一个数字或者布尔值,就不需要使用双引号。
总结一下,当遇到这个错误时,我们需要检查代码中所有的字段名,并确保它们前后都被双引号包围。只有这样,解析器才能正确地处理JSON数据。