Elasticsearch搜索结果过滤

I am new to Elasticsearch and I am using REST API for PHP to play around with data returned. I am using following code to retrieve data.

$params = [
        'index' => 'my_search',
        'type' => 'mytype',
        'from' => 0,
        'size' => 10,
        'body' => [
            'query' => [
                'bool' => [
                    'must' => [
                        [ 'match' => [ 'validated' => true ] ],
                        [ 'match' => [ 'image' => true ] ]
                    ]
                ]
            ],
            'sort' => [
                'created_at' => [ 'order' => 'asc']
            ]
        ]
    ];

Above code returns data perfectly matching "validated=>true" and "image=>true".

Further I want to add open text search like we use /_search/?q=Apple macbook. I have tried to use match, multi_match, query_string options, but couldn't get success.

So, I want to retrieve results from ES that have "validated=>true", "image=>true" and matches with text "Apple macbook".

Thanks in advance.

You can try with query_string or simple_query_string

$params = [
    'index' => 'my_search',
    'type' => 'mytype',
    'from' => 0,
    'size' => 10,
    'body' => [
        'query' => [
            'bool' => [
                'must' => [
                    [ 'match' => [ 'validated' => true ] ],
                    [ 'match' => [ 'image' => true ] ],
                    [ 'query_string' => [ 'query' => 'Apple macbook' ] ]
                ]
            ]
        ],
        'sort' => [
            'created_at' => [ 'order' => 'asc']
        ]
    ]
    ];



$params = [
    'index' => 'my_search',
    'type' => 'mytype',
    'from' => 0,
    'size' => 10,
    'body' => [
        'query' => [
            'bool' => [
                'must' => [
                    [ 'match' => [ 'validated' => true ] ],
                    [ 'match' => [ 'image' => true ] ],
                    [ 'simple_query_string' => [ 'query' => 'Apple macbook' ] ]
                ]
            ]
        ],
        'sort' => [
            'created_at' => [ 'order' => 'asc']
        ]
    ]
    ];

you can also do this by enabling all_field mapping for your index, you can do that by following the below URL https://www.elastic.co/guide/en/elasticsearch/reference/current/mapping-all-field.html and then use the below ES query:

$params = [
        'index' => 'my_search',
        'type' => 'mytype',
        'from' => 0,
        'size' => 10,
        'body' => [
            'query' => [
                'bool' => [
                    'must' => [
                        [ 'match' => [ '_all' => 'Apple macbook' ] ],
                        [ 'match' => [ 'validated' => true ] ],
                        [ 'match' => [ 'image' => true ] ]
                    ]
                ]
            ],
            'sort' => [
                'created_at' => [ 'order' => 'asc']
            ]
        ]
    ];