fffjq 2013-08-01 01:52 采纳率: 0%
浏览 2084

spring怎么获得当前的connection啊?

在applicationContext.xml里配置datasource用的ProxoolDataSource,
sqlmapclient配置用这个这个datasource
出现了一个问题 就是sqlmapclient把autocommit设为false没有作用,因为想做个批处理
我想获取spring当前sqlmapclient的connection 将它设为非自动提交,怎么做啊?

我查到下面方法:

通过DataSourceUtils.getConnection(DataSource);就能获取到设置的DataSource 然后获得connection

public static Connection getConnection()
throws SQLException
{

return DataSourceUtils.getConnection((DataSource)ServiceLocator.getBean("dataSource"));

}

但是ServiceLocator没有啊?
用sqlMapClient.getDataSource().setAutoCommit(false) 没有用,再sqlMapClient.getDataSource().getAutoCommit();还是true!!。。。。。

求解求解 求大神

  • 写回答

1条回答 默认 最新

  • ChatGPTᴼᴾᴱᴺᴬᴵ 2023-01-09 19:17
    关注

    在 Spring 中,您可以通过注入 DataSource 或者 DataSourceTransactionManager bean 来获取当前的 Connection。


    首先,您可以在您的 DAO 类中注入 DataSource,然后调用 getConnection() 方法获取 Connection。这是一个示例代码:

    @Autowired
    private DataSource dataSource;
    
    public void doSomething() throws SQLException {
        Connection conn = dataSource.getConnection();
        // use the connection to execute SQL statements
        conn.close();
    }
    

    如果您想在事务中执行批处理操作,您可以注入 DataSourceTransactionManager bean,然后使用它的 getConnection() 方法获取 Connection。这是一个示例代码:

    @Autowired
    private DataSourceTransactionManager transactionManager;
    
    @Transactional
    public void doBatchUpdate() throws SQLException {
        Connection conn = transactionManager.getConnection();
        conn.setAutoCommit(false);
        // use the connection to execute SQL statements in batch mode
        conn.commit();
        conn.close();
    }
    

    注意:在使用完 Connection 后,一定要记得关闭它。

    评论

报告相同问题?

悬赏问题

  • ¥15 求daily translation(DT)偏差订正方法的代码
  • ¥15 js调用html页面需要隐藏某个按钮
  • ¥15 ads仿真结果在圆图上是怎么读数的
  • ¥20 Cotex M3的调试和程序执行方式是什么样的?
  • ¥20 java项目连接sqlserver时报ssl相关错误
  • ¥15 一道python难题3
  • ¥15 牛顿斯科特系数表表示
  • ¥15 arduino 步进电机
  • ¥20 程序进入HardFault_Handler
  • ¥15 关于#python#的问题:自动化测试