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

Combinazione illegale di errori di confronto da MySql durante l'esecuzione della suite di test rails

L'aggiunta della raccolta:utf8_general_ci al file database.yml come hai fatto dovrebbe fare il trucco. Prova a ricreare il database di test usando "rake RAILS_ENV=test db:migrate:reset db:fixtures load" - avviso questo cancellerà tutti i dati che hai lì oltre i dispositivi.

Ha funzionato per me. Per verificare vedere le regole di confronto su database, tabelle e colonne puoi eseguire quanto segue:

-- Database Collations:
SELECT schema_name,default_character_set_name,default_collation_name 
FROM information_schema.SCHEMATA 
WHERE schema_name not IN ('mysql');

-- Table Collations:
SELECT T.table_schema, T.table_name, T.TABLE_COLLATION, CCSA.CHARACTER_SET_NAME 
FROM information_schema.`TABLES` T,
 information_schema.`COLLATION_CHARACTER_SET_APPLICABILITY` CCSA
WHERE CCSA.collation_name = T.table_collation
AND T.table_schema not IN ('mysql');

-- Column Collations:
SELECT table_schema, table_name, column_name, collation_name, character_set_name
FROM information_schema.`COLUMNS` C
WHERE C.table_schema not IN ('mysql')
ORDER BY 1,2,4;

Tutto nel tuo database di test dovrebbe ora avere le regole di confronto specificate in database.yml.