一次数据库varchar字段长度设置问题引发的异常

先上图

--- 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代表该数据类型所允许保存的字符串的最大长度,只要长度小于该最大值的字符串都可以被保存在该数据类型中, 而当插入的数据长度超出长度时, 有以下两种情况:
  1. 在MySQL处于严格模式下, 超过了长度就会报错.
  2. 非严格模式下, 插入值会被截断为合适的长度后入库

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值