使用命令行方式登陆到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编码的灵活性。特别是不利于软件的国际化。
           (2)放弃命令行窗口登录MySQL,使用图形化客户端。客户端工具可以MySQL的官方网站上找到。

最新文章

  1. Centos7 升级内核和应用TCP BBR 算法
  2. JavaScript 的错误(Error)与异常(Exception)处理
  3. HDU 1069 dp最长递增子序列
  4. UVA 1366 九 Martian Mining
  5. [python]实现单机版一行wordcount
  6. POJ3928、LA4329【树状数组】
  7. solr 高亮配置
  8. 烽火HG220G 配置
  9. ld: 18 duplicate symbols for architecture i386 .linker command failed with exit code 1 (use -v to see invocation)_
  10. EBS收单方/收货方
  11. 组件vue传值
  12. Visual Studio 20年
  13. 原始套接字-自定义IP首部和TCP首部
  14. [lr & ps] 色彩空间管理
  15. HTML5新增的本地存储功能(笔记)
  16. BZOJ 1032 JSOI 2007 祖码Zuma 区间DP
  17. 微信小程序数据分析之自定义分析
  18. hbase 批量插入api
  19. 我的Android进阶之旅------>解决Android Studio编译后安装apk报错:The APK file does not exist on disk
  20. 搭建Easyui环境在Myeclipse或Eclipse中

热门文章

  1. MyBatis无限输出日志
  2. centos7 部署 dotnetcore
  3. spring的cglib代理
  4. Nginx+Tomcat+Redis实现集群搭建
  5. 负载均衡之DNS域名解析
  6. 在阿里云上安装python3.4和pycharm
  7. Ceph Monitor基础架构与模块详解
  8. iOS自动化探索(五)自动化测试框架pytest - Assert断言的使用
  9. ARM汇编指令集3
  10. WPF控件开源资源