3

在 dao 中使用注解

@Repository("testDao")
public class TestDaoImpl extends JdbcDaoSupport implements BaseDao{

@Override
public Object addObject(String sqlid, Object obj) {
    // TODO Auto-generated method stub
    return null;
}

引起:java.lang.IllegalArgumentException:需要“dataSource”或“jdbcTemplate”

我不想用:</p>

<bean id="termsDao" class="com.manage.base.dao.impl.TestDaoImpl">
    <property name="jdbcTemplate" ref="jdbcTemplate"/>
</bean>

这段代码是在xml中设置的,而“jdbcTemplate”已经在其他“spring-xml”中定义了。</p>

如何通过注解解决这个问题:“'dataSource' or 'jdbcTemplate' is required”</p>

4

2 回答 2

5

您可以使用以下方法之一。第一个 - 首选/推荐使用数据源,因为您不会在公共接口中公开 SpringFramework 类。两者都会起作用。

@Repository("testDao")
public class TestDaoImpl extends JdbcDaoSupport implements BaseDao{

  @Autowired
  TestDaoImpl(DataSource dataSource) {
    setDataSource(dataSource);
  }
}

或者

@Repository("testDao")
public class TestDaoImpl extends JdbcDaoSupport implements BaseDao{

  @Autowired
  TestDaoImpl(JDBCTemplate template) {
    setJdbcTemplate(template);
  }
}
于 2012-05-13T14:33:00.453 回答
0

我什至觉得将数据源作为 DAO 的构造函数注入是不必要的编码步骤。为什么不将 Spring config XML 中的数据源注入 JDBC 模板,然后在每个 DAO 中获取 jdbctTemplate 对象。

<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
    <property name="dataSource" ref="dataSource"/>
</bean>
and let your DAO extend JDBCSupport class.

public class PersonDao extends JdbcDaoSupport{
public List<Person> selectAll(){
    String selectAllSql = "SELECT * FROM PERSON;";

    return getJdbcTemplate().query(selectAllSql, new PersonRowMapper());

........ }

}

完整示例: http: //www.studytrails.com/frameworks/spring/spring-jdbc-dao-support.jsp

于 2014-04-13T23:35:55.513 回答