先上图
--- Cause: com.mysql.jdbc.MysqlDataTruncation: Data truncation: Data too long for column 'activity_id' at row 1; nested exception is com.ibatis.common.jdbc.exception.NestedSQLException:
图中的异常很明显, activity_id字段的长度不够用了, 实际插入的数据长度超出activity_id字段的预设值.
查看数据库表activity_id字段的设置: varchar(50), 在设置这个值的时候, 我误以为varchar类型的字段即使设置了长度, 在入库时如果实际数据长度超过了最大值, mysql会自动给我扩容(或者截断数据入库), 结果没有, 直接报错了.
注意⚠️
- varchar(M)可以保存可变长度的字符串. 其中M代表该数据类型所允许保存的字符串的最大长度,只要长度小于该最大值的字符串都可以被保存在该数据类型中, 而当插入的数据长度超出长度时, 有以下两种情况:
- 在MySQL处于严格模式下, 超过了长度就会报错.
- 非严格模式下, 插入值会被截断为合适的长度后入库