问题描述
现在又一个应用,在web启动时不想让它连接数据库,如果在web启动时就自动出始化数据库连接,那么数据库连接出现问题就会使应用起不起来,现在就是要求能在应用中用到数据库,调用持久层数据时,在初始化数据库实例。现在有个方案不知可行吗,1.在web.xml中配置时先不让web启动就自动加载有关数据库初始化的配置文件,而是在以后需要数据库连接访问的应用时,通过获取配置文件,获得相应的bean实现。2.对applicationcontext.xml中的有关数据源的bean设置lazy-init=true.谁能给个可行方法,希望介绍详细点,orm采用hibernate。 问题补充:其实你说的很有道理,但是我说的和你理解的需求稍微有点偏差,现在是因为应用中有些不使用数据库的应用,也是希望数据库不能连接的情况下,对其他不需要数据库的应用不造成影响,所以还要求在spring初始化实例时,不希望初始化有关数据库的实例,而是在应用操作用到持久化操作时候在连接数据库,其实现的主要目标是实现两方面业务的分离。不知道你还有没有什么好的可行的方法可以满足我的需求,还望赐教。
解决方案
引用enet_java 写道定义datasource,但是不要将datasource注入到任何dao层。 在需要jdbc时,可以通过datacource实例来获取数据库的连接。 那我配置好dataSource和sessionFactory bean后,在dao层在hibernateDaoSupport的继承类中通过setSuperSessionFactory方法重新设置sessionFactory,那么在dao的实现类中能否直接调用相应的方法,这样能够实现吗? public class CustomHibernateDaoSupport extends HibernateDaoSupport { ApplicationContext ctx = new ClassPathXmlApplicationContext("classpath:dataSource.xml") @Autowired public void setSuperSessionFactory(SessionFactory sessionFactory) { setSessionFactory(sessionFactory); } } ....................... public class HibernateLogDataDAO extends CustomHibernateDaoSupport implements LogDataDAO{ //持久化操作; } 这样做可行吗,能达到目的吗?谢谢。 可以,通过注入的sessionFactory就可以得到JDBC连接了。
解决方案二:
定义datasource,但是不要将datasource注入到任何dao层。在需要jdbc时,可以通过datacource实例来获取数据库的连接。
解决方案三:
如果通过初始化获取数据库的连接,可以通过orm或者是spring来进行连接池的维护和实物的管理,自己通过根据需要来进行获取的话,就算实现不知道性能如何,我没有过这种应用,不敢多说。不过我个人感觉这种需求不是很合理,如果启动的时候数据库出现了问题,你敢保证你通过程序获取数据库连接的时候就可以成功?