java - MySQL数据截断: Out of range value for column

标签 java mysql ibatis

我正在使用 ibatis 和 java webapp 插入一行。 POJO 有一个字段需要存储一个数字(比如 3.0 或 2.34)。我试过在 Java 端使用 BigDecimal 和 Double。在 MySQL 端,我使用的是 Decimal(5, 5) 数据类型。

当我尝试插入一个以“4”作为该数字字段值的行时,MySQL 和 iBatis 抛出以下异常:

org.springframework.jdbc.UncategorizedSQLException: SqlMapClient operation: encountered SQLException [  
--- The error occurred in org/mySQL.xml.  
--- The error occurred while applying a result map.  
--- Check the mySQL.insertQuery.  
--- The error happened while setting a property on the result object.  
--- Cause: java.lang.RuntimeException: org.springframework.jdbc.UncategorizedSQLException: SqlMapClient operation: encountered SQLException [  
--- The error occurred while applying a parameter map.  
--- Check the insertQuery-InlineParameterMap.  
--- Check the statement (update failed).  
--- Cause: com.mysql.jdbc.MysqlDataTruncation: Data truncation: Out of range value for column 'numericColumn' at row 316]; nested exception is com.ibatis.common.jdbc.exception.NestedSQLException:   
    at com.ibatis.sqlmap.engine.mapping.statement.GeneralStatement.executeQueryWithCallback(GeneralStatement.java:188)
    at com.ibatis.sqlmap.engine.mapping.statement.GeneralStatement.executeQueryWithRowHandler(GeneralStatement.java:133)
    at com.ibatis.sqlmap.engine.impl.SqlMapExecutorDelegate.queryWithRowHandler(SqlMapExecutorDelegate.java:649)
    at com.ibatis.sqlmap.engine.impl.SqlMapSessionImpl.queryWithRowHandler(SqlMapSessionImpl.java:156)
    at com.ibatis.sqlmap.engine.impl.SqlMapClientImpl.queryWithRowHandler(SqlMapClientImpl.java:133)
    at org.springframework.orm.ibatis.SqlMapClientTemplate$5.doInSqlMapClient(SqlMapClientTemplate.java:267)
    at org.springframework.orm.ibatis.SqlMapClientTemplate.execute(SqlMapClientTemplate.java:165)
    at org.springframework.orm.ibatis.SqlMapClientTemplate.queryWithRowHandler(SqlMapClientTemplate.java:265)
    at org.myClass(myClass.java:83)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:324)
    at org.springframework.util.MethodInvoker.invoke(MethodInvoker.java:248)
    at org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean$MethodInvokingJob.executeInternal(MethodInvokingJobDetailFactoryBean.java:165)
    at org.springframework.scheduling.quartz.QuartzJobBean.execute(QuartzJobBean.java:66)
    at org.quartz.core.JobRunShell.run(JobRunShell.java:191)
    at org.quartz.simpl.SimpleThreadPool$WorkerThread.run(SimpleThreadPool.java:516)

我是否为要插入的值使用了错误的 java 数据类型?如果不是,为什么 MySQL 不让我插入值?

最佳答案

您似乎误解了如何在 SQL 中定义 DECIMAL(或可能的 NUMERIC)列 -
具体来说,当将列定义为 DECIMAL(x, y) 时,x 是该列将存储的位数, >y 是小数点后 的位数。因此,在您的列定义中,您指定了 -1 < column < 1 的范围。数据类型是正确的,但您正试图指定列被告知允许的范围之外的值。 幸运的是,修复很简单:更改列定义。我假设您希望在小数点前 有最多 5 位数字,这将使列定义 DECIMAL(10, 5)

关于java - MySQL数据截断: Out of range value for column,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12057695/

相关文章:

java - Android 的 GoogleSignInClient.signOut() 不会注销用户

php - while 循环不显示从数据库收集的所有数据

mysql - 如何为mysql中的子查询赋予默认值?

java - Apache ibatis postgresql selectList 它是如何工作的

java - 如何使用 XML 风格的 MyBatis-SpringBoot-MySQL 执行正确的 SQL INSERT?

java - 带保证消息处理的 WordCount

java - 将 ArrayList 拆分为多个 ArrayList

java - 如何使用 MyBatis 从 SQL 调用存储过程

java - 使用 sax 解析器解析和修改 xml 字符串

mysql - LEFT JOINS 在 MySQL 中创建多行