获取prepareStatement的可能的数据类型-Java DB2

时间:2018-07-04 10:02:00

标签: java sql db2 prepared-statement

在插入值之前,有什么方法可以让PreparedStatement接受数据类型吗?

方案是我正在获取Excel(或OpenOffice)文档,我对其进行了解析以将数据导入数据库。有时,如果要表示数字0,则Excel中的单元格会留空。 有没有办法从准备好的插入语句中获取列类型,以确保我必须解析哪个数据类型的值?

我认为应该可以通过事先在表上运行select语句并仅查看ResultSet元数据来实现。但是,如果可能的话,我想解决这个问题。

2 个答案:

答案 0 :(得分:1)

PreparedStatement不支持。它可以让您设置任何数据类型,但是当您执行查询时,对于不匹配的数据类型,您将得到SQLException

最好的选择是使用SYSTEM CATALOG视图来标识列数据类型,并相应地设置/推导值。

DB2具有此视图SYSCAT.COLUMNS,可以为您提供所需的信息。

答案 1 :(得分:0)

您可以从准备好的语句中获取参数元数据,它除其他外还包含参数数据类型。

ParameterMetaData metadata = preparedStatement.getParameterMetaData();
int type = metadata.getParameterType(col);

Java文档getParameterMetaData()