c#写了一个mysql插入语句,插入中文字符串时上报异常:
MySql.Data.MySqlClient.MySqlException (0x80004005): Incorrect string value。
这个问题,最终是通过这个方法解决的:
alter table mytablename convert to character set utf8mb4 collate utf8mb4_bin;
把存在字符编码冲突的表的字符编码,调整为utf8mb4格式。再次运行上面问题解决。
原始返回的错误如下:
2021-04-23 11:02:19:985:MySql.Data.MySqlClient.MySqlException (0x80004005): Incorrect string value: ‘\xE6\x96\xAD\xE7\xBA\xBF…’ for column ‘warnname’ at row 1
在 MySql.Data.MySqlClient.MySqlStream.ReadPacket()
在 MySql.Data.MySqlClient.NativeDriver.GetResult(Int32& affectedRow, Int64& insertedId)
在 MySql.Data.MySqlClient.Driver.GetResult(Int32 statementId, Int32& affectedRows, Int64& insertedId)
在 MySql.Data.MySqlClient.Driver.NextResult(Int32 statementId, Boolean force)
在 MySql.Data.MySqlClient.MySqlDataReader.NextResult()
在 MySql.Data.MySqlClient.MySqlCommand.ExecuteReader(CommandBehavior behavior)
在 MySql.Data.MySqlClient.MySqlCommand.ExecuteNonQuery()
在 DataCollector.MainForm.report_warning_counter(String deviceid, Int32 warnid, String warnname, UInt64 count) 位置
参考:https://www.cnblogs.com/inaruto/p/11305536.html