Объединение имени и использование concat снова для имени пользователя?

Я пытаюсь извлечь информацию из базы данных с помощью PHP и получить следующий запрос:

$q = "SELECT CONCAT_WS(' ',FirstName,MiddleName,LastName) AS Name,
      (NewCustomerID) AS customerid,
      substring('Firstname',1,1, 'MiddleName'),
      left(MiddleName,1) AS MN,
      (LastName) AS LN
       FROM customer 
       Where FN.MN.LN = 'username'"; 
$r = mysqli_query ($dbc, $q);
$num = mysqli_num_rows($r);

когда я запускаю это, я получаю информацию, но не имя пользователя, которое мне нужно:

$q = "SELECT CONCAT_WS(' ',FirstName,MiddleName,LastName) AS Name,
      (NewCustomerID) AS customerid,
      left('Firstname',1) as FN,
      left(MiddleName,1) AS MN,
      (LastName) AS LN 
            FROM customer".

Просто застрял, попробовал немало вещей и просто не могу заставить его работать.

3 ответа

Решение
$q = "SELECT CONCAT(left(FirstName,1),left(MiddleName,1),LastName) AS UserName, CONCAT_WS(' ',LastName,FirstName) AS Name, (NewCustomerID) AS customerid FROM customer ";

Поскольку FN, MN, а также LN псевдонимы, вы должны использовать HAVING вместо WHERE,

HAVING FN.MN.LN = 'username'

Хоть, FN.MN.LN это синтаксическая ошибка, я полагаю, вы имели в виду CONCAT(FN,MN,LN)?

HAVING CONCAT(FN,MN,LN) = 'username'

Вы не правильно цитируете запрос, Имя - это имя столбца:

SELECT 
    CONCAT_WS(' ',FirstName,MiddleName,LastName) AS Name,
    (NewCustomerID) AS customerid,
    LEFT(Firstname,1) as FN, 
    LEFT(MiddleName,1) AS MN,
    (LastName) AS LN
FROM customer
WHERE CONCAT(FN,MN,LN) = 'username'
Другие вопросы по тегам