Объединение имени и использование 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'