Как запросить строковое значение, разделенное запятой в MySQL?

0

результат 1 из таблицы 1:

select types from table1 where id = 123456;

результат:

934046, 934049

то результат 1 как параметр таблицы 2:

select GROUP_CONCAT(name) from table2 where id in (
    select types from table1 where id = 123456
);

но результат 1 является строковым значением, поэтому результат:

NULL

infact Я хочу получить это:

select GROUP_CONCAT(name) from table2 where id in ('934046', '934049');
or
select GROUP_CONCAT(name) from table2 where id in (934046,934049);

но это может все еще так:

select GROUP_CONCAT(name) from table2 where id in ('934046,934049');

1.
select REPLACE(types,',','\',\'') types from table1 where id=123456

1.1 
result:  934046',' 934049

1.2 
select GROUP_CONCAT(name) from table2 where ids in ( 
select REPLACE(types,',','\',\'') types from table1 where id=123456
); 

2.
select CONCAT('\'',REPLACE(types ,',','\',\''),'\'') from table1 where 
id=123456

2.1 
reuslt: '934046',' 934049' 

2.2 
select GROUP_CONCAT(name) from table2 where ids in ( 
select CONCAT('\'',REPLACE(types ,',','\',\''),'\'') from table1 where 
id=123456); 

это строковое значение не может быть в качестве параметра. Что делать, чтобы получить идентификаторы правильно?

  • 0
    если types является varchar, то select GROUP_CONCAT(name) from table2 where id in ('934046', '934049') является подходящим для использования
  • 0
    Я знаю проблему, но она не может работать
Показать ещё 4 комментария
Теги:

2 ответа

0
select GROUP_CONCAT(t.name) from table2 t
where exists(
    select 1 from table1
    where id = 123456
    and LOCATE(concat(', ', t.id, ',') , concat(', ', types, ',') )>0
)
  • 0
    кто-то дает ответ, но я не знаю, почему он его удалил. в любом случае, спасибо всем
  • 0
    Хотя этот код может ответить на вопрос, предоставление дополнительного контекста относительно того, почему и / или как этот код отвечает на вопрос, повышает его долгосрочную ценность.
0
$query = "select types from table1 where id = 123456"; 

$result = mysql_query($query) or die(mysql_error());

$array = array();

while($row = mysql_fetch_array($result))
{
   $array[] = $row['types'];
}

$array = implode(",",$array);

$query2 = "select GROUP_CONCAT(name) from table2 where id in ($array)";

Я создал код с другим запросом.

Ещё вопросы

Сообщество Overcoder
Наверх
Меню