ERROR 1366 (HY000): Incorrect string value:’XXX’ for column 'XXX at row 1解决

159 篇文章 113 订阅
90 篇文章 1 订阅

环境

MySQL Server 5.5.27 + 命令行工具


问题

插入中文字符数据出现如下错误:

 

ERROR 1366 (HY000): Incorrect stringvalue: '\xBD\xF1\xCC\xEC\xCC\xEC...' for co

lumn 'MESSAGECONTENT' at row 1


环境再现 

--以下是插入语句:
insert into sms_inbox values('123456','123456', 'cd', sysdate(), '今天天
气很好', 1, sysdate(), '123456');
 
--报错:
ERROR 1366 (HY000): Incorrect stringvalue: '\xBD\xF1\xCC\xEC\xCC\xEC...' for co
lumn 'MESSAGECONTENT' at row 1
 
--解决:设置编码
set names gbk;
 
Query OK, 0 rows affected (0.02 sec)


 

总结

当出现乱码,就是编码的问题,可以尝试设置数据库的编码(set nams gbk)。





这个错误是由于将一个空字符串赋值给 `status` 列的整数类型字段导致的。根据错误信息和错误码,错误 1366 (HY000) 表示 "Incorrect integer value",意味着在插入或更新操作中,将无效的整数值赋值给了整数类型的列。 要解决这个问题,你可以考虑以下几个方面: 1. 检查数据源:确保数据源中的值是有效的整数值。空字符串不能直接转换为整数,你可以使用合适的条件检查或转换函数来处理空值。 2. 检查表结构:确认表结构中 `status` 列的数据类型是整数类型(如 INT、BIGINT)而非字符串类型(如 VARCHAR)。如果列的数据类型是字符串类型,那么可以将空字符串直接存储到该列中。 3. 处理空值:如果你希望将空字符串转换为整数类型的零值存储到数据库中,你可以在赋值之前进行判断和处理。例如,在赋值之前检查字符串是否为空,如果为空则将整数字段设置为零值。 下面是一个示例代码,展示了如何处理空字符串并将其转换为整数类型的零值: ```go package main import ( "database/sql" "fmt" "log" _ "github.com/go-sql-driver/mysql" ) type User struct { ID int Name string Status int } func main() { db, err := sql.Open("mysql", "username:password@tcp(localhost:3306)/database") if err != nil { log.Fatal(err) } defer db.Close() user := User{ ID: 1, Name: "John", Status: 0, } // 处理空字符串 if user.Status == 0 { user.Status = 0 // 设置为零值 } // 插入数据到数据库 insertQuery := "INSERT INTO users (id, name, status) VALUES (?, ?, ?)" _, err = db.Exec(insertQuery, user.ID, user.Name, user.Status) if err != nil { log.Fatal(err) } fmt.Println("数据插入成功") } ``` 在上面的示例中,我们创建了一个 `User` 结构体,并将 `status` 字段设置为零值。在插入数据到数据库之前,我们检查 `status` 字段的值,如果为零,则将其设置为零值。然后,我们使用 `db.Exec()` 执行插入操作将数据存储到数据库中。 请根据你的实际需求和数据源来调整代码,并确保你的数据源中的值是有效的整数或为空字符串。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值