您的位置:首页 > 数据库 > MySQL

com.mysql.jdbc.MysqlDataTruncation: Data truncation: Division by 0

2018-04-13 00:00 363 查看
摘要: com.mysql.jdbc.MysqlDataTruncation: Data truncation: Division by 0

### The error may involve com.restyle.api.dao.mybatis.WatchUserMapper.insertSelective-Inline
### The error occurred while setting parameters
### Cause: com.mysql.jdbc.MysqlDataTruncation: Data truncation: Division by 0
; SQL []; Data truncation: Division by 0; nested exception is com.mysql.jdbc.MysqlDataTruncation: Data truncation: Division by 0
at org.springframework.jdbc.support.SQLStateSQLExceptionTranslator.doTranslate(SQLStateSQLExceptionTranslator.java:102)

以前用的是mysql5.6.x没问题,更新到mysql5.7.x后出现了这个问题:

1, 看系统日志Division by 0就各种折腾,数据库降级,没成功;
2, 最后发现是新增数据时在触发器中使用了TRUNCATE(NEW.FIGHT_WINN / NEW.FIGHT_COUNT,2) * 100,所以提示报错;
3, 数据库以及各种配置文件在修改前要备份,数据库要以脚本形式备份;
4, 数据库中尽量不要使用视图,触发器,函数之类的,以免给自己挖坑,尤其是sql逻辑不严谨的问题;
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  MySQL Division
相关文章推荐