2

实际上我正在尝试调用 queryForInt() 方法,但它显示 NULL 异常。当我使用以下代码访问具有相同凭据的 dB 时:

----------------这是工作-----------

DriverManagerDataSource dataSource = new DriverManagerDataSource();
dataSource.setDriverClassName("oracle.jdbc.driver.OracleDriver");
dataSource.setUrl("jdbc:oracle:thin:@localhost:1521:xe");
dataSource.setUsername("userName");
dataSource.setPassword("pwd");

------ 在 Bean 中 ------(这不起作用)

<!-- DAOS -->
<bean id="ProductDAO" class="br.edeploy.voive.dao.ProductDAO">
    <property name="dataSource" ref="dataSource"/>
</bean>

---------在 ProductDAO 类上 --------------(我使用 Spring 方法时抛出异常)

try
{
  int i = getSimpleJdbcTemplate().queryForInt("Select * from ERP_PRODUCT", "");
}
catch(DataAccessException dax)
{
  throw new Exception("Error: "+dax.getMessage());
}

谢谢。

4

1 回答 1

0

Spring jdbcTemplate.queryForInt() 支持以下参数

 int    queryForInt(String sql) 
          Execute a query that results in an int value, given static SQL.

 int    queryForInt(String sql, Object[] args) 
          Query given SQL to create a prepared statement from SQL and a list of arguments to bind to the query, resulting in an int value.

 int    queryForInt(String sql, Object[] args, int[] argTypes) 
          Query given SQL to create a prepared statement from SQL and a list of arguments to bind to the query, resulting in an int value.

您为参数传递参数,不确定为什么使用第二种方法而不是第一种方法(当您不需要传递参数时)

编辑 使用 queryForInt() 的方法是:

String sql = "SELECT COUNT(*) FROM CUSTOMER";

int total = getJdbcTemplate().queryForInt(sql);

查看您的代码,看起来您需要使用queryForObject()

String sql = "SELECT NAME FROM CUSTOMER WHERE CUST_ID = ?";

String name = (String)getJdbcTemplate().queryForObject(
            sql, new Object[] { custId }, String.class);
于 2012-10-16T09:04:59.377 回答