Как использовать операторы в массиве шин - PullRequest
1 голос
/ 29 мая 2019

Я пытаюсь использовать оператор => в массиве, но запрос использует оператор в качестве привязки

Model::updateOrCreate([
        ['client_id', $client->id],
        ['created_at', '=>', '2019-05-01 00:00:00',],
    ],
    [
        'client_id' => $client->id,
    ]
);

Это не работает, запрос выглядит так

[
    "query"    =>
        "select * from `models` where (`client_id` = ? and `created_at` = ?) limit 1",
    "bindings" => [
        0 => 5,
        1 => "=>",
    ],
];

Я искал в Интернете и не смог найти соответствующую документацию для функции addArrayOfWheres

Спасибо.

1 Ответ

7 голосов
/ 29 мая 2019

=> не является допустимым оператором для предложений, вы должны использовать >=.

Полный список разрешенных операторов можно найти в исходном коде .

/**
 * All of the available clause operators.
 *
 * @var array
 */
public $operators = [
    '=', '<', '>', '<=', '>=', '<>', '!=', '<=>',
    'like', 'like binary', 'not like', 'ilike',
    '&', '|', '^', '<<', '>>',
    'rlike', 'regexp', 'not regexp',
    '~', '~*', '!~', '!~*', 'similar to',
    'not similar to', 'not ilike', '~~*', '!~~*',
];
...