sql >> Base de Datos >  >> RDS >> Mysql

Divida una cadena MYSQL de GROUP_CONCAT en una (matriz, como, expresión, lista) que IN () pueda entender

En lugar de usar IN() , usaría FIND_IN_SET() ser una opción también?

http://dev.mysql .com/doc/refman/5.0/en/string-functions.html#function_find-in-set

mysql> SELECT FIND_IN_SET('b','a,b,c,d');
    -> 2

Aquí hay un ejemplo completo basado en el problema de ejemplo en la pregunta, confirmado como probado por el autor de la pregunta en una edición anterior de la pregunta:

SELECT name FROM person LEFT JOIN tag ON person.id = tag.person_id GROUP BY person.id 
  HAVING ( FIND_IN_SET(1, GROUP_CONCAT(tag.tag_id)) ) AND ( FIND_IN_SET(2, GROUP_CONCAT(tag.tag_id)) );
+------+
| name |
+------+
| Bob  |
+------+