2017-03-07 14 views
0

update_by_queryメソッドを使用してドキュメントを更新しようとすると、python-elasticsearchクライアント-elasticsearch.pyを使用しており、弾性検索でクエリを解析できません。弾性検索 - クエリの解析に失敗しました

次のように私の更新の体は次のとおりです。

{ 
    'script': { 
    'inline': 'ctx._source.viewers += info', 
    'params': { 
     'info': { 
     'time': datetime.datetime(2017, 3, 7, 18, 8, 50), 
     'viewer': '[email protected]' 
     } 
    } 
    } 
} 

次のように弾性検索が呼ばれた::

update = es.update_by_query(index=index_el, 
          doc_type='1', 
          q='delivery_reference_id:' + str(cam_id) +'', 
          body=doc) 

cam_idのサンプル値は次のとおりです。

内部
CAM_10_DATA_4_2017-03-07 18:02:07 

、次のクエリが形成されます::

エラーが受信

http://127.0.0.1:9200/user_tracker/1/_update_by_query?q=delivery_reference_id%3ACAM_10_DATA_4_2017-03-07+18%3A02%3A07

次のようにされて次のように完全なエラーログがある

TransportError(400, 'search_phase_execution_exception', 'Failed to parse query [delivery_reference_id:CAM_10_DATA_4_2017-03-07 18:02:07]') 

:誰かがそれを考え出した場合

Traceback (most recent call last): 
    File "C:\Users\catch\AppData\Roaming\Python\Python34\site-packages\django\core\handlers\exception.py", line 42, in inner 
    response = get_response(request) 
    File "C:\Users\catch\AppData\Roaming\Python\Python34\site-packages\django\core\handlers\base.py", line 187, in _get_response 
    response = self.process_exception_by_middleware(e, request) 
    File "C:\Users\catch\AppData\Roaming\Python\Python34\site-packages\django\core\handlers\base.py", line 185, in _get_response 
    response = wrapped_callback(request, *callback_args, **callback_kwargs) 
    File "C:\Users\catch\AppData\Roaming\Python\Python34\site-packages\django\views\decorators\csrf.py", line 58, in wrapped_view 
    return view_func(*args, **kwargs) 
    File "C:\Users\catch\AppData\Roaming\Python\Python34\site-packages\django\views\generic\base.py", line 68, in view 
    return self.dispatch(request, *args, **kwargs) 
    File "C:\Python34\lib\site-packages\rest_framework\views.py", line 483, in dispatch 
    response = self.handle_exception(exc) 
    File "C:\Python34\lib\site-packages\rest_framework\views.py", line 443, in handle_exception 
    self.raise_uncaught_exception(exc) 
    File "C:\Python34\lib\site-packages\rest_framework\views.py", line 480, in dispatch 
    response = handler(request, *args, **kwargs) 
    File "C:\Users\catch\PycharmProjects\myproject\myproj\apis\views.py", line 516, in get 
    viewer=viewer_email) 
    File "C:\Users\catch\PycharmProjects\myproject\myproj\apis\views.py", line 541, in update_track_info 
    doc=doc) 
    File "C:\Users\catch\PycharmProjects\myproject\myproj\apis\views.py", line 553, in es_update 
    body=doc) 
    File "C:\Python34\lib\site-packages\elasticsearch\client\utils.py", line 73, in _wrapped 
    return func(*args, params=params, **kwargs) 
    File "C:\Python34\lib\site-packages\elasticsearch\client\__init__.py", line 680, in update_by_query 
    doc_type, '_update_by_query'), params=params, body=body) 
    File "C:\Python34\lib\site-packages\elasticsearch\transport.py", line 318, in perform_request 
    status, headers, data = connection.perform_request(method, url, params, body, ignore=ignore, timeout=timeout) 
    File "C:\Python34\lib\site-packages\elasticsearch\connection\http_urllib3.py", line 128, in perform_request 
    self._raise_error(response.status, raw_data) 
    File "C:\Python34\lib\site-packages\elasticsearch\connection\base.py", line 122, in _raise_error 
    raise HTTP_EXCEPTIONS.get(status_code, TransportError)(status_code, error_message, additional_info) 
elasticsearch.exceptions.RequestError: TransportError(400, 'search_phase_execution_exception', 'Failed to parse query [delivery_reference_id:CAM_10_DATA_4_2017-03-07 18:02:07]') 

がいいだろう。もっと情報が必要な場合はお知らせください。

ありがとうございます。前もって感謝します。

+0

あなたは何ESバージョンを使用している:私は、次の構文を使用して良い結果を持っていましたか? – Alfe

+0

弾性検索バージョン:5.2.0 –

答えて

0

あなたのクエリの構文が最新ではないと思います。

{ 
    "query": { 
    "bool": { 
     "must": [ 
     { "match": { "MYFIELD": "myoldvalue" } } 
     ] 
    } 
    }, 
    "script": { 
    "inline": "ctx._source.MYFIELD = \"mynewvalue\"", 
    "lang": "painless" 
    } 
} 

HTH :)

+0

python-elasticsearchクライアントを使用して上記のリクエストを行うにはどうすればよいですか? –

+0

上記で指定した本文をthisに置き換えます。 – paqash

+0

私は 'update_by_query'メソッドを使用しています。 '{ 'スクリプト':{ 'インライン': 'ctx._source.viewers + =情報'、 'paramsは':{ '情報':{ を「しかし、私は私が試した –