mysql workbench插入表数据时有中文就报错,怎么解决
展开全部
“使用命令行方式登陆到mysql服务器,
建立一个数据库,数据库编码设为utf-8。此时,如果直接在命令行窗口使用insert语句插入中文,就遇到类似
error
1406
(22001):
data
too
long
for
column
'name'
at
row
1
错误。乍一看,是字段长度引起的问题,但是实际是字符编码的问题。可是尝试以下解决方法:
1、在linux中,使用终端方式登陆mysql服务器,运行以下命令:
set
names
utf8;
该命令将终端的字符编码设为了utf-8。此后再插入数据库中的内容都会按照utf-8的编码来处理。
注意:在linux中,终端方式中直接插入中文内容,可能并不会出现1406错误,但是这时插入的数据
是按照系统的默认编码进行处理。因此对编码为utf-8的数据库,在显示数据的地方可能会出现乱码。
2、在windows下,命令行窗口不支持utf-8编码,所以使用“set
names
utf8;”不会达到转化中文的
效果。但是这个问题还是可以解决的:
(1)使用默认编码建立数据库。这种情况下就可以直接输入中文了,但是相应的问题,就是会
建立一个数据库,数据库编码设为utf-8。此时,如果直接在命令行窗口使用insert语句插入中文,就遇到类似
error
1406
(22001):
data
too
long
for
column
'name'
at
row
1
错误。乍一看,是字段长度引起的问题,但是实际是字符编码的问题。可是尝试以下解决方法:
1、在linux中,使用终端方式登陆mysql服务器,运行以下命令:
set
names
utf8;
该命令将终端的字符编码设为了utf-8。此后再插入数据库中的内容都会按照utf-8的编码来处理。
注意:在linux中,终端方式中直接插入中文内容,可能并不会出现1406错误,但是这时插入的数据
是按照系统的默认编码进行处理。因此对编码为utf-8的数据库,在显示数据的地方可能会出现乱码。
2、在windows下,命令行窗口不支持utf-8编码,所以使用“set
names
utf8;”不会达到转化中文的
效果。但是这个问题还是可以解决的:
(1)使用默认编码建立数据库。这种情况下就可以直接输入中文了,但是相应的问题,就是会
ZESTRON
2024-09-04 广告
2024-09-04 广告
在Dr. O.K. Wack Chemie GmbH,我们高度重视ZESTRON的表界面分析技术。该技术通过深入研究材料表面与界面的性质,为提升产品质量与可靠性提供了有力支持。ZESTRON的表界面分析不仅涵盖了相变化、化学反应、吸附与解吸...
点击进入详情页
本回答由ZESTRON提供
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询
广告 您可能关注的内容 |