Warning: file_get_contents(/data/phpspider/zhask/data//catemap/0/windows/17.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java BeanPropertySqlParameterSource和Double_Java_Spring_Sybase - Fatal编程技术网

Java BeanPropertySqlParameterSource和Double

Java BeanPropertySqlParameterSource和Double,java,spring,sybase,Java,Spring,Sybase,在Sybase中设置一个表和存储过程,如下所示: 创建表testtab(f float) 创建proc insert_testtab@f float作为insert testtab值(@f) 和一个java对象,该对象包含一个 class TestObj { Double getF() { return 12.34; } } 使用SimpleJDBCall&BeanPropertySqlParameterSource: SqlParameterSource params = new BeanP

在Sybase中设置一个表和存储过程,如下所示:

创建表testtab(f float)

创建proc insert_testtab@f float作为insert testtab值(@f)

和一个java对象,该对象包含一个

class TestObj { Double getF() { return 12.34; } }
使用SimpleJDBCall&BeanPropertySqlParameterSource:

SqlParameterSource params = new BeanPropertySqlParameterSource(new TestObj());
SimpleJdbcCall call = new SimpleJdbcCall(dataSource).withProcedureName("insert_testtab");
call.execute(params);
结果是12.0被插入到数据库中,而不是12.34。在封面下面,BeanPropertySqlParameterSource似乎将数字作为java.sql.Types.NUMERIC传递给存储过程,并截断小数


有人能解释一下吗?这可能是Spring中Sybase代码的问题,还是我做得不正确?

最好是向BeanPropertySqlParamterSource对象注册属性类型。否则,Spring将在底层CallableStatement上使用setObject。这就让JDBC驱动程序实现决定如何处理数据。类似于
params.registerSqlType(“f”,java.sql.Types.DECIMAL)
的东西应该可以做到这一点。您还需要将params声明为
BeanPropertySqlParameterSource
的一个实例,这样才能工作。

您确定Sybase中的列设置正确吗?我以前在其他数据库中见过这种情况,当数字列只设置为整数(或精度为零)时。谢谢,我会尝试一下,BeanPropertySqlParameterSource不是提供了吗?这样您就不必提供参数名称和类型了?这对我来说似乎是个bug,我也这么认为,但我使用的JDBC驱动程序不能很好地处理对setObject的调用,导致了与您看到的类似的问题。您必须了解正在使用的特定JDBC驱动程序如何处理Double,才能确定它是否是一个bug。