Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770
Форумы портала PHP.SU :: Версия для печати :: конкатенация строк
Форумы портала PHP.SU » PHP » SQL и Архитектура БД » конкатенация строк

Страниц (1): [1]
 

1. b.magadan - 12 Апреля, 2016 - 20:50:48 - перейти к сообщению
Добрый вечер. Окажите помощь пожалуйста.
Имеется следующий запрос:

CODE (SQL):
скопировать код в буфер обмена
  1. SELECT q.id AS question_id, a.id AS answer_id
  2.                 FROM questions q
  3.                 LEFT JOIN answers a
  4.                         ON q.id = a.parent_question
  5.                 LEFT JOIN test
  6.                         ON test.id = q.parent_test
  7.                                 WHERE q.parent_test = 10 AND a.correct_answer = '1' AND test.enable = '1'



В итоге получаем следующую таблицу:
CODE (SQL):
скопировать код в буфер обмена
  1.  
  2. question_id  answer_id
  3. 8                22
  4. 9                24
  5. 9                25



Вопрос в следующем: как конкатенацией сделать что бы в результате получилась таблица из двух строк?
2. T1grOK - 12 Апреля, 2016 - 20:56:09 - перейти к сообщению
Если Mysql, то:
CODE (SQL):
скопировать код в буфер обмена
  1. SELECT GROUP_CONCAT(a.id),.......GROUP BY q.id
3. b.magadan - 12 Апреля, 2016 - 21:32:50 - перейти к сообщению
T1grOK пишет:
Если Mysql, то:
CODE (SQL):
скопировать код в буфер обмена
  1. SELECT GROUP_CONCAT(a.id),.......GROUP BY q.id


q.id надо оставить.
Спасибо за наводку, все получилось. Вот так работает
CODE (SQL):
скопировать код в буфер обмена
  1. SELECT q.id AS question_id, GROUP_CONCAT(a.id) AS answer_id
  2. ....
  3. GROUP BY q.id

 

Powered by ExBB FM 1.0 RC1