Используйте CONCAT внутри CONCAT в mysql - PullRequest
0 голосов
/ 11 февраля 2020

У меня есть хранимая процедура, и ее часть:

SET @TableAlias = " ls_flock AS _flk ";
SET @Select = CONCAT(
    " _flk.Id as Id, _flk.Code as Code, ",
    CONCAT(" _em.FirstName", " ", "_em.LastName "), -- here I want to CONCAT 2 columns as one field.
    " as FlockManager"
  );
SET @Join = " JOIN employee as _em ON _flk.EmployeeId = _em.Id ";

Я не могу СОХРАНИТЬ два столбца как поле с функцией CONCAT.

И если я удалите следующую строку, код работает нормально:

CONCAT(" _em.FirstName", " ", "_em.LastName "), -- here I want to CONCAT 2 columns as one field.
    " as FlockManager"

Я получаю эту ошибку:

У вас есть ошибка в вашем синтаксисе SQL; проверьте руководство, соответствующее вашей версии сервера MySQL, чтобы узнать правильный синтаксис для использования рядом с '.LastName как FlockManager FROM ls_flock AS _flk ПРИСОЕДИНЯЙТЕСЬ до сотрудника как _em ON _flk.' в строке 1

1 Ответ

3 голосов
/ 11 февраля 2020

Я подозреваю, что вы хотите сгенерировать строку запроса, которая использует CONCAT() - потому что я вижу, что псевдоним таблицы _em объявлен далее в переменной @Join. Для этого вам нужно переместить функцию в строку запроса.

SET @Select = CONCAT(
    " _flk.Id as Id, ",
    "_flk.Code as Code, ",
    "CONCAT(_em.FirstName, "" "", _em.LastName) s FlockManager"
;

И тогда вам просто не нужно внешнее CONCAT():

SET @Select = 
    " _flk.Id as Id, _flk.Code as Code, CONCAT(_em.FirstName, "" "", _em.LastName) as FlockManager";
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...