Heim > Datenbank > MySQL-Tutorial > Wie behebt man den Fehler „Unzulässige Sortierungsmischung' in MySQL-Abfragen?

Wie behebt man den Fehler „Unzulässige Sortierungsmischung' in MySQL-Abfragen?

Patricia Arquette
Freigeben: 2024-11-03 23:59:30
Original
1079 Leute haben es durchsucht

How to Resolve

Unzulässige Auflösung der Zeichensortierung in MySql mit Sortierungsfehler

Beim Versuch, zwei Unterabfragen in einer SQL-Abfrage zu kombinieren, kann es sein, dass Sie auf die Meldung „Illegal“ stoßen Fehler „Mix of Collations“. Dies tritt auf, wenn die an Vergleichen oder Vorgängen beteiligten Spalten unterschiedliche Zeichensätze oder Sortiereinstellungen haben.

Um diesen Fehler zu beheben, muss sichergestellt werden, dass die in der Abfrage verwendeten Spalten dieselbe Sortierung haben. Um die betroffenen Spalten zu ermitteln, verwenden Sie die folgende Abfrage:

SELECT table_schema, table_name, column_name, character_set_name, collation_name
FROM information_schema.columns
WHERE collation_name = 'latin1_general_ci'
ORDER BY table_schema, table_name,ordinal_position;
Nach dem Login kopieren

Dadurch werden die Spalten mit der Sortierung „latin1_general_ci“ angezeigt. Um den Fehler zu beheben, konvertieren Sie die widersprüchlichen Spalten mit dieser Abfrage in die Sortierung „latin1_swedish_ci“:

ALTER TABLE tbl_name CONVERT TO CHARACTER SET latin1 COLLATE 'latin1_swedish_ci';
Nach dem Login kopieren

Durch Behebung der Sortierungsinkongruenz kann die Abfrage erfolgreich ausgeführt werden:

SELECT username, (SUM(rating)/COUNT(*)) as TheAverage, Count(*) as TheCount
FROM ratings WHERE month='Aug' 
AND username IN (SELECT username FROM users WHERE gender =1)
GROUP BY username HAVING TheCount > 4
ORDER BY TheAverage DESC, TheCount DESC
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonWie behebt man den Fehler „Unzulässige Sortierungsmischung' in MySQL-Abfragen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage