Für MySQLChinesischProblem mit verstümmeltem Code (meins ist Ubuntu System) Ich habe viele Lösungen im Internet gelesen und dabei viele Umwege gemacht. Deshalb habe ich darüber nachgedacht, einen Artikel basierend auf meiner eigenen Lösung zu schreiben, um ihn mit bedürftigen Freunden zu teilen. Daher stellt dieser Artikel hauptsächlich vor, wie man Ubuntu Download löst Die relevanten Informationen zum MySQL-Chinesisch-Code-Problem können darauf verwiesen werden
Entdecken Sie das Problem
Ich habe Django Kürzlich ist bei der Verwendung von zum Einfügen von Daten das folgende Problem aufgetreten:
/usr/local/lib/python2.7/dist-packages/Django-1.11.dev20170117002028-py2.7.egg /django/db/backends/mysql/base.py:109: Warning: Incorrect string value: '\xE6\x88\x90\xE5\x8A\x9F...' for column 'json' at row 1 return self.cursor.execute(query, args) [07/Feb/2017 12:15:21] "GET /index/ HTTP/1.1" 200 250Chinesisch kann nicht in die MySQL-Datenbank eingefügt werden~!
Datenbankkodierung ändern
mysql> show create database bangjob; +----------+--------------------------------------------------------------------+ | Database | Create Database | +----------+--------------------------------------------------------------------+ | bangjob | CREATE DATABASE `bangjob` /*!40100 DEFAULT CHARACTER SET latin1 */ | +----------+--------------------------------------------------------------------+ 1 row in set (0.00 sec)
mysql> show variables like'%char%'; +--------------------------+----------------------------+ | Variable_name | Value | +--------------------------+----------------------------+ | character_set_client | utf8 | | character_set_connection | utf8 | | character_set_database | latin1 | | character_set_filesystem | binary | | character_set_results | utf8 | | character_set_server | latin1 | | character_set_system | utf8 | | character_sets_dir | /usr/share/mysql/charsets/ | +--------------------------+----------------------------+ 8 rows in set (0.00 sec)
Geänderte Ergebnisse anzeigen
mysql> set character_set_database=utf8; Query OK, 0 rows affected (0.00 sec) mysql> set character_set_server=utf8; Query OK, 0 rows affected (0.00 sec)
Es wird zu diesem Zeitpunkt kein Problem sein, mit dem Einfügen fortzufahren
mysql> show variables like'%char%'; +--------------------------+----------------------------+ | Variable_name | Value | +--------------------------+----------------------------+ | character_set_client | utf8 | | character_set_connection | utf8 | | character_set_database | utf8 | | character_set_filesystem | binary | | character_set_results | utf8 | | character_set_server | utf8 | | character_set_system | utf8 | | character_sets_dir | /usr/share/mysql/charsets/ | +--------------------------+----------------------------+ 8 rows in set (0.00 sec)Es wäre großartig, wenn die Einstellungen des Autors nach dem Neustart von MySQL ungültig wären 🎜>
Weiter! Suchen Sie nach anderen Methoden
Fügen Sie die Informationen im entsprechenden Knoten der my.cnf-Datei hinzu:
Dann starten Sie MySQL neu:sudo gedit /etc/mysql/my.cnfWenn Sie neu starten können, überprüfen Sie die Datenbankkodierung erneut:
[client] default-character-set=utf8 [mysqld] default-character-set=utf8 [mysql] default-character-set=utf8
/etc/init.d/mysql startEs wäre großartig, wenn dies wahr wäre:
mysql> show variables like "%char%"; +--------------------------+----------------------------+ | Variable_name | Value | +--------------------------+----------------------------+ | character_set_client | utf8 | | character_set_connection | utf8 | | character_set_database | utf8 | | character_set_filesystem | binary | | character_set_results | utf8 | | character_set_server | utf8 | | character_set_system | utf8 | | character_sets_dir | /usr/share/mysql/charsets/ | +--------------------------+----------------------------+ 8 rows in set (0.01 sec)
Als ich den MySQL-Dienst neu startete, stellte ich fest, dass er sich im Wartezustand befand (PS: Ich vermute, dass zu diesem Zeitpunkt ein Deadlock oder etwas anderes aufgetreten ist, führen Sie Folgendes aus). 🎜 >
eine Ausnahme auslösen:
mysql -u root -p
Ich möchte nur die Kodierung ändern, warum ist das so schwierig->-> -> ;->->!!!Ich habe viele Methoden ausprobiert (Neustart, Wiederherstellung).
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/run/mysqld/mysqld.sock' (2)Diese Methoden können das Problem nicht lösen, beginnen wir mit dem Protokoll... Suchen Sie die Datei /var/log/mysql/error.log
sudo /etc/init.d/mysql status
mysql respawn/post-start, (post-start) process 55665
Weiter zur Lösung für
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/run/mysqld/mysqld.sock' (2)
Natürlich muss die zuvor erstellte Datenbank neu gestartet werden. erstellt T_T
Weil die vor der Anzeige erstellte Datenkodierung immer noch latin1 ist
Zusammenfassungdefault-character-set=utf8'
character_set_server=utf8
Das obige ist der detaillierte Inhalt vonEinführung in die Lösung des Problems verstümmelter chinesischer Zeichen in MySQL unter Ubuntu. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!