zoukankan      html  css  js  c++  java
  • MySQL #1406 Data too long错误

    首先,我在写这篇记录的时候其实问题还没有解决,一直显示同一个问题——date too long

    我查了很多网上的解决方法,差不多就是两种解决方式,而两种我都试过了,准备先把这两种方法记录下来,后面真正解决完再来编辑。

    A. 字符编码:

       “使用命令行方式登陆到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的官方网站上找到。”

    B. Mysql配置文件:
       “在my.ini里找到sql- mode='STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION'把其中 的STRICT_TRANS_TABLES,去掉,或者把sql- mode=STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION注释掉,然 后重启mysql就ok了”
     
    我先是用的第二种方法,没解决掉,再用了第一种,等我解决掉了再来编辑。
  • 相关阅读:
    CentOS 6.3下安装腾达USB无线网卡遇到的问题及解决方法
    验证resneXt,densenet,mobilenet和SENet的特色结构
    比较语义分割的几种结构:FCN,UNET,SegNet,PSPNet和Deeplab
    比较 VGG, resnet和inception的图像分类效果
    强化学习基础
    深度学习的知识点
    卷积神经网络CNN
    信息论的知识点
    理论机器学习
    计算理论基础
  • 原文地址:https://www.cnblogs.com/zrc-study/p/6429697.html
Copyright © 2011-2022 走看看