mysql 中文字符集问题错误解决办法

字符集出现错误解决办法
  出现的问题:
  mysql> update users
  -> set username='关羽'
  -> where userid=2;
  ERROR 1366 (HY000): Incorrect string value: '\xB9\xD8\xD3\xF0' for column 'usern
  ame' at row 1
  向表中插入中文字符时,出现错误。
  
  mysql> select * from users;
  +--------+----------+
  | userid | username |
  +--------+----------+
  | 2 | ???? |
  | 3 | ???? |
  | 4 | ?í?ù |
  +--------+----------+
  3 rows in set (0.00 sec)
  表中的中文字符位乱码。
  解决办法:
  使用命令:
  mysql> status;
  --------------
  mysql Ver 14.12 Distrib 5.0.45, for Win32 (ia32)
  
  Connection id: 8
  Current database: test
  Current user: root@localhost
  SSL: Not in use
  Using delimiter: ;
  Server version: 5.0.45-community-nt MySQL Community Edition (GPL)
  Protocol version: 10
  Connection: localhost via TCP/IP
  Server characterset: latin1
  Db characterset: latin1
  Client characterset: gbk
  Conn. characterset: gbk
  TCP port: 3306
  Uptime: 7 hours 39 min 19 sec
  Threads: 2 Questions: 174 Slow queries: 0 Opens: 57 Flush tables: 1 Open ta
  bles: 1 Queries per second avg: 0.006
  --------------
  查看mysql发现Server characterset,Db characterset的字符集设成了latin1,所以出现中文乱码。
  
  mysql> show tables;
  +----------------+
  | Tables_in_test |
  +----------------+
  | users |
  +----------------+
  1 row in set (0.00 sec)
  
  更改表的字符集。
  mysql> alter table users character set GBK;
  Query OK, 3 rows affected (0.08 sec)
  Records: 3 Duplicates: 0 Warnings: 0
  
  查看表的结构:
  mysql> show create users;
  ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that
  corresponds to your MySQL server version for the right syntax to use near 'users
  ' at line 1
  mysql> show create table users;
  +-------+-----------------------------------------------------------------------
  ------------------------------------------------------------------------------+
  | Table | Create Table
  |
  +-------+-----------------------------------------------------------------------
  ------------------------------------------------------------------------------+
  | users | CREATE TABLE `users` (
  `userid` int(11) default NULL,
  `username` char(20) character set latin1 default NULL
  ) ENGINE=InnoDB DEFAULT CHARSET=gbk |
  +-------+-----------------------------------------------------------------------
  ------------------------------------------------------------------------------+
  1 row in set (0.00 sec)
  
  mysql> desc users;
  +----------+----------+------+-----+---------+-------+
  | Field | Type | Null | Key | Default | Extra |
  +----------+----------+------+-----+---------+-------+
  | userid | int(11) | YES | | NULL | |
  | username | char(20) | YES | | NULL | |
  +----------+----------+------+-----+---------+-------+
  2 rows in set (0.02 sec)
  
  这时向表中插入中文然后有错误。
  mysql> insert into users values(88,'中文');
  ERROR 1366 (HY000): Incorrect string value: '\xD6\xD0\xCE\xC4' for column 'usern
  ame' at row 1
  mysql> insert into users values(88,'中文');
  ERROR 1366 (HY000): Incorrect string value: '\xD6\xD0\xCE\xC4' for column 'usern
  ame' at row 1
  
  还要更改users表的username的字符集。
  mysql> alter table users modify username char(20) character set gbk;
  ERROR 1366 (HY000): Incorrect string value: '\xC0\xEE\xCB\xC4' for column 'usern
  ame' at row 1
  mysql> alter table users modify username char(20) character set gbk;
  ERROR
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
错误码1366通常是指在MySQL数据库中插入或更新数据时,出现了不正确的整数值错误。有几种可能的解决方法可以尝试。 一种解决方法是修改字段的默认值。这意味着将字段的默认值更改为正确的整数值,以便在插入或更新数据时不会出现错误1366。具体的步骤可以参考中提供的解决方法。 另一种可能的原因是数据库表不支持中文字符集,导致存放中文出现错误。可以通过查询MySQL当前编码的方式来确认数据库和服务器的字符集是否为latin1。如果是latin1字符集,它是不支持中文的。因此,需要将字符集修改为支持中文字符集,如utf8。可以使用命令"show variables like 'character%'"来查看当前编码。如果发现是latin1字符集,可以按照中的步骤进行修改。 总之,要解决MySQL错误1366,可以尝试修改字段的默认值或修改数据库和服务器的字符集。希望这些解决方法能对您有所帮助。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Mysql错误1366 - Incorrect integer value解决方法](https://download.csdn.net/download/weixin_38717574/12831717)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [MYSQL 1366错误解决方法](https://blog.csdn.net/Nathan_Yang/article/details/104931529)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值