开发者社区> 问答> 正文

报错SQLSTATE[HY000]: General error: 1366 Incorrect string value

落地花开啦 2016-06-17 16:38:20 2677

SQLSTATE[HY000]: General error: 1366 Incorrect string value: 'xE4xB8x8AxE5xAEx98...' for column 'content' at row 1

mysqld version: 5.6
字符设置成utf-8

后来,根据此帖子:http://drupal.stackexchange.com/questions/88327/pdoexception-sqlstatehy000-general-error-1366-incorrect-string-value-wh
怀疑是mysql 中utf-8 支持的字符集有限,所以改成了 utf8mb4,但是并没有解决问题。

求助各位大侠。

关系型数据库 MySQL
分享到
取消 提交回答
全部回答(1)
  • 落地花开啦
    2019-07-17 19:43:06

    因为是用的PDO,而且SQL语句比较长。就没有把SQL语句给贴出来。
    原PHP语句是:
    BookArticle::create(array('title' => $title, 'content' => $article_content, 'book_id' => $book->id, 'spider_url' => $url));
    我用的是laravel 框架。

    执行的时候报错:
    SQLSTATE[HY000]: General error: 1366 Incorrect string value: 'xE4xB8x8AxE5xAEx98...' for column 'content' at row 1

    我想办法clean utf8 code,依然没办法插入。

    后来只想打印出SQL,在phpmyadmin里执行一下.

    $sql = "insert into book_articles set title='$title',content='$article_content',book_id=$book_id";

    phpmyadmin里的出错信息是 data too long for text ...

    把text换成longtext 问题解决。

    0 0
+ 订阅

分享数据库前沿,解构实战干货,推动数据库技术变革

推荐文章
相似问题
推荐课程