zoukankan      html  css  js  c++  java
  • mysql导入文件出现Data truncated for column 'xxx' at row 1的原因

    mysql导入文件的时候很容易出现"Data truncated for column 'xxx' at row x",其中字符串里的xxx和x是指具体的列和行数.

    有时候,这是因为数据类型的不对应,或者字符串长度不够而造成的.

    但是,经常出现row 1就报错,并且感觉它没什么不对的样子.

    这往往是因为windows的回车换行" "作怪,下面的测试说明了这种情况.

    我有一个train.csv的数据文件,我用python修改后保存为c.csv.

    但是,我用相同的命令把它们导入到mysql时,train能导入,c却出错.

    我把行结束符从" "换成" "后,导入成功.

    用notepad打开这两个文件,会发现train根本没有换行,而c则有换行.

    这说明train里只有" ",因此notepad无法识别到换行,而c里则是" ".

    然而用python生成c.csv的时候,输出只有" ",这说明python在win下会自动把" "变成" ".

    还有一点是,除了notepad外的大部分win下的编辑器,都既能识别" "又能识别" ".

    因此只有用notepad才能知道到底是" "还是" ",或者用winHex等工具直接看ascii码.

    最后的结论是,注意这个数据文件的换行到底是" "还是" ".

  • 相关阅读:
    Centos7
    appium+python常见报错(appium方面)
    python标准库之datetime
    python异常捕获
    python写入文件和读取文件
    python标准库之collections
    python导入类
    python3+robotframework+pycharm安装运行
    python 继承/父类和子类的关系
    python_类
  • 原文地址:https://www.cnblogs.com/lxwphp/p/9055280.html
Copyright © 2011-2022 走看看