Heim  >  Artikel  >  Datenbank  >  Einführung in die Lösung des Problems verstümmelter chinesischer Zeichen in MySQL unter Ubuntu

Einführung in die Lösung des Problems verstümmelter chinesischer Zeichen in MySQL unter Ubuntu

黄舟
黄舟Original
2017-03-29 13:43:521180Durchsuche

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 250
Chinesisch 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.cnf

Wenn 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 start
Es 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). 🎜 >

wird

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

Antwort:


[ mysqld ] Weiter geändert in

Nun, MySQL kann endlich neu gestartet werden und die nach dem Neustart festgelegte Codierung wird weiterhin wirksam

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!

Stellungnahme:
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