1. 程式人生 > >MySQL 1366錯誤解決辦法

MySQL 1366錯誤解決辦法

eat 服務 來看 status 編碼 ddr not hang direct

MySQL 1366錯誤大致描述如下

  1. SQL Error: 1366: Incorrect string value: "xE8xAFxA6xE7xBBx86…" for column "address" at row 1

解決辦法:檢查數據庫此字段的字符集與整理字符集是否與SQL語句傳遞數據的字符集相同;不相同則會引發MySQL1366錯誤。

修改MySQL該字段的字符集與整理規則即可。假設數據表為phplamp, SQL語句的字符集為utf8,出錯的字段為address:

MySQL 1366 錯誤解決辦法
  1. #檢查數據表所有字段的狀態
  2. ->show full columns from phplamp;
  3. #發現address字段的Collation項非utf8,修改它!
  4. ->alter table phplamp change name name varchar(100) character set utf8 collate utf8_unicode_ci not null default ‘‘;

修改完字段的字符集後可以再使用show full columns from table_name命令檢查一下,以確保萬無一失。假如您的SQL字符集為GBK或是GB2312或是其它的話,只需要將數據表字段的字符集更改為其相應的編碼即可。

mysql[ERROR 1366 (HY000):錯誤]中文顯示問題

mysql的字符集用utf8也解決不了中文的編碼問題,用gbk才能解決。所以總結一下如果更改編碼:
停掉mysql服務,修改my.ini文件,修改兩處default-character-set=gbk。啟動mysql服務。再次插入,還是有問題。

用status看了一下:

mysql> status;

原來

Current database:  order_movie_ticket

Server characterset: utf8

Db characterset: utf8

Client characterset: gbk

Conn. characterset: gbk

雖然Client characterset和Conn. characterset都改成了gbk, Db characterset的字符集還是utf8,所以仍出現中文亂碼。

所以要把它設回gbk,用alter命令。

mysql> alter database order_movie_ticket character set gbk;

因為只改了order_movie_ticket這一個db,所以直接用status查結果還是Db characterset的字符集為utf8,但是若轉入order_movie_ticket,只看他自己的

mysql> use order_movie_ticket;

再用status看一下,這回對了。再次插入數據,這回正確了。

要註意的是以上改的前提是database order_movie_ticket裏是空的,如果它的一些表裏已經有數據就不能只改db了,還要用alter命令改相應的table,

如:mysql> alter table movie character set gbk;

可以通過如下命令

mysql> show create table movie; 來看表的create命令形式的結構和表的字符集。

----------------------------------------------------------

movie | create table ‘movie‘ (

‘movie_id‘ bigint(20) not null auto_increment,

‘name‘ varchar(50) not null,

‘actor‘ varchar(100) not null,

‘director‘ varchar(30) not null,

‘classification‘ varchar(30) default null,

‘story‘ varchar(200) default null,

‘valid‘ char(1) not null default ‘Y‘,

primary key (‘movie_id‘)

) ENGINE=InnoDB DEFAULT CHARSET=gbk

MySQL 1366錯誤解決辦法