Mysql
 sql >> Database >  >> RDS >> Mysql

MySQL:ricerca l'elenco delle opzioni disponibili per SET

Ora, questo è semplicemente impazzito, ma è solo MySQL e funziona!

SELECT TRIM("'" FROM SUBSTRING_INDEX(SUBSTRING_INDEX(
   (SELECT TRIM(')' FROM SUBSTR(column_type, 5)) FROM information_schema.columns 
    WHERE table_name = 'some_table' AND column_name = 'some_column'),
',', @r:[email protected]+1), ',', -1)) AS item
FROM (SELECT @r:=0) deriv1,
(SELECT ID FROM information_schema.COLLATIONS) deriv2
HAVING @r <= 
   (SELECT LENGTH(column_type) - LENGTH(REPLACE(column_type, ',', ''))
    FROM information_schema.columns
    WHERE table_name = 'some_table' AND column_name = 'some_column');

Sostituisci semplicemente "qualche_tabella" e "qualche_colonna" per la tua tabella/colonna specifica e guarda la magia!

Vedrai uno strano utilizzo di "information_schema.COLLATIONS" - questo perché abbiamo bisogno di una tabella lì - qualsiasi tabella - contenente almeno N righe , dove N è il numero di elementi nel tuo set.