首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >单例vs原型JdbcTemplate

单例vs原型JdbcTemplate
EN

Stack Overflow用户
提问于 2013-07-01 16:25:06
回答 2查看 4.3K关注 0票数 2

在Spring文档中,建议使用JdbcTemplate的方法是为您在...中使用的每个类创建new模板。

代码语言:javascript
复制
public class JdbcCorporateEventDao implements CorporateEventDao {

    private JdbcTemplate jdbcTemplate;

    public void setDataSource(DataSource dataSource) {
        this.jdbcTemplate = new JdbcTemplate(dataSource);
    }

}

我想知道,与在上下文中将jdbctemplate定义为单例并直接将其注入Dao相比,这种解决方案有什么优势

代码语言:javascript
复制
 public class JdbcCorporateEventDao implements CorporateEventDao {
        @Autowired
        private JdbcTemplate jdbcTemplate;

        public void setJdbcTemplate(JdbcTemplate jdbcTemplate) {
            this.jdbcTemplate = jdbcTemplate;
        }

    }
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-07-02 10:49:50

来自JdbcTemplate的类级文档:

代码语言:javascript
复制
 * Can be used within a service implementation via direct instantiation
 * with a DataSource reference, or get prepared in an application context
 * and given to services as bean reference.

任何一种都可以。在这里,我有一个大型应用程序(50个DAO,100个并发用户),并且有一个用于整个应用程序的jdbcTemplate对象,该对象在spring上下文中定义。这可以很好地工作。

票数 4
EN

Stack Overflow用户

发布于 2014-03-20 00:08:44

直接注入JdbcTemplate的一个缺点是,如果您需要/决定使用SQLExceptionTranslator

如果您的JdbcTemplate是单例的,则在任何类中设置SQLExceptionTranslator都会影响使用该模板的所有类。

例如..。

代码语言:javascript
复制
public class JbdcUserDAO implements UserDAO{

    @Autowired
    private JdbcTemplate jdbcTemplate;

    public JbdcUserDAO() {
        this.jdbcTemplate.setExceptionTranslator(new UserSQLExceptionTranslator());
    }

    public void setJdbcTemplate(JdbcTemplate jdbcTemplate) {
        this.jdbcTemplate = jdbcTemplate;
    }

}

代码语言:javascript
复制
public class JdbcCompanyDAO implements CompanyDAO{

    @Autowired
    private JdbcTemplate jdbcTemplate;

    public JdbcCompanyDAO() {

    }

    public void setJdbcTemplate(JdbcTemplate jdbcTemplate) {
        this.jdbcTemplate = jdbcTemplate;
    }
}

通过JdbcCompanyDAO提出的SQLException也将通过UserSQLExceptionTranslator运行,即使它看起来没有注册转换器。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/17400129

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档