Heim >Datenbank >MySQL-Tutorial >Detaillierte Erklärung der Lösung für verstümmelte Zeichen in SQL-Befehlsabfragen
Dieser Artikel beschreibt die Lösung für den verstümmelten Code in der SQL-Befehlsabfrage Wenn Sie die Lösung für den verstümmelten Code in der SQL-Befehlsabfrage nicht kennen oder an der Lösung für den verstümmelten Code interessiert sind Code in der SQL-Befehlsabfrage, dann Schauen wir uns diesen Artikel gemeinsam an. Okay, kommen wir ohne weitere Umschweife zum Punkt
1. Der Server selbst hat Probleme behoben, z. B. bleibt er in Latein hängen1
|
|
1
2 3 4 |
|
Verwenden Sie die obige Codierungsmethode Änderung:
set Character_set_results=gb2312; und es wird normal angezeigt!
Über GBK, GB2312, UTF8
UTF-8: Unicode Transformation Format-8bit, BOM ist erlaubt, aber normalerweise nicht Enthält Stückliste. Es handelt sich um eine Multibyte-Kodierung zur Lösung internationaler Zeichen. Sie verwendet 8 Bit (d. h. ein Byte) für Englisch und 24 Bit (drei Byte) für Chinesisch. UTF-8 enthält Zeichen, die von allen Ländern der Welt verwendet werden. Es handelt sich um eine internationale Kodierung und eine große Vielseitigkeit. UTF-8-codierter Text kann in Browsern in verschiedenen Ländern angezeigt werden, die den UTF8--Zeichensatz unterstützen. Wenn es sich beispielsweise um eine UTF8-Codierung handelt, kann Chinesisch auch im englischen IE von Ausländern angezeigt werden, und sie müssen das chinesische Sprachunterstützungspaket des IE nicht herunterladen.
GBK ist ein Standard, der auf dem nationalen Standard GB2312 basiert und erweitert wurde, um mit GB2312 kompatibel zu sein. Die Textkodierung von GBK wird durch Doppelbytes dargestellt, das heißt, sowohl chinesische als auch englische Zeichen werden durch Doppelbytes dargestellt. Um chinesische Zeichen zu unterscheiden, werden die höchsten Bits auf 1 gesetzt. GBK enthält alle chinesischen Zeichen und ist eine nationale Kodierung. Es ist weniger vielseitig als UTF8, belegt aber eine größere Datenbank als GBD.
GBK, GB2312 usw. müssen durch Unicode-Kodierung in UTF8 konvertiert werden:
GBK, GB2312--Unicode--UTF8
UTF8--Unicode--GBK, GB2312
Wenn auf einer Website oder in einem Forum viele englische Zeichen vorhanden sind, wird empfohlen, UTF-8 zu verwenden, um Platz zu sparen. Allerdings unterstützen viele Forum-Plug-ins mittlerweile generell nur GBK.
GB2312 ist eine Teilmenge von GBK, die eine Teilmenge von GB18030 ist.
GBK ist ein großer Zeichensatz, der chinesische, japanische und koreanische Zeichen enthält.
Wenn es sich um eine chinesische Website handelt, wird GB2312 manchmal immer noch empfohlen einige Probleme
Um alle verstümmelten Codeprobleme zu vermeiden, sollte UTF-8 verwendet werden. Es wird auch in Zukunft sehr praktisch sein, die Internationalisierung zu unterstützen
UTF-8 kann als angesehen werden großer Zeichensatz, der die Kodierung des größten Teils des Textes enthält.
Ein Vorteil der Verwendung von UTF-8 besteht darin, dass Benutzer in anderen Regionen (z. B. Hongkong und Taiwan) Ihren Text normal und ohne verstümmelte Zeichen anzeigen können, ohne die Unterstützung für vereinfachtes Chinesisch installieren zu müssen.
gb2312 ist der Code für vereinfachtes Chinesisch
gbk unterstützt vereinfachtes Chinesisch und traditionelles Chinesisch
big5 unterstützt traditionelles Chinesisch
utf-8 unterstützt fast alle Zeichen
Analysieren Sie zunächst das Verstümmelte Codesituation
Mehrere Zeichensätze in MySQL beteiligt
character-set-server/default-character-set: Server-Zeichensatz, standardmäßig verwendet.
character-set-database: Datenbankzeichensatz.
Zeichensatztabelle: Zeichensatz der Datenbanktabelle.
Priorität erhöht sich nacheinander. Daher muss unter normalen Umständen nur der Zeichensatzserver festgelegt werden, und der Zeichensatz wird beim Erstellen von Datenbanken und Tabellen nicht angegeben. Auf diese Weise ist der Zeichensatzserver einheitlich gebraucht. character-set-client: Der Zeichensatz des Clients. Standardzeichensatz des Clients. Wenn ein Client eine Anfrage an den Server sendet, wird die Anfrage in diesem Zeichensatz codiert.
character-set-results: Ergebniszeichensatz. Wenn der Server Ergebnisse oder Informationen an den Client zurückgibt, werden die Ergebnisse in diesem Zeichensatz codiert.
Wenn auf der Client-Seite die Zeichensatzergebnisse nicht definiert sind, wird der Zeichensatz des Zeichensatz-Clients als Standardzeichensatz verwendet. Sie müssen also nur den Zeichensatz „character-set-client“ festlegen.
Über das chinesische Problem von MySQL
Der Weg, den verstümmelten Code zu lösen, besteht darin, die folgenden drei Systemparameter von MySQL so einzustellen, dass sie mit dem Zeichensatz des Servers übereinstimmen Ausführen der SQL-Anweisung. Derselbe Zeichensatz wie bei set-server.character_set_client: Der Zeichensatz des Clients.
character_set_results: Ergebniszeichensatz.
character_set_connection: Verbindungszeichensatz.
Legen Sie diese drei Systemparameter fest, indem Sie Anweisungen an MySQL senden: set name gb2312
Verwandte Empfehlungen:
SQL-AbfrageWie man in einem Array verwendet
Geheimnisse zur Beschleunigung von SQL-Abfragen, um zu verhindern, dass Datenbankcode die Datenbank blockiert
Komplexe Abfragen von MySQL-Abfrageanweisungen
Das obige ist der detaillierte Inhalt vonDetaillierte Erklärung der Lösung für verstümmelte Zeichen in SQL-Befehlsabfragen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!