基于javabean的B/S程序数据库连接解决方案

基本思路,建立一个全局数据库session,共所有javabean使用。


建立一个公共的类,如main.class,设置成application。

import org.hibernate.cfg.*;
import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.jbpm.JbpmConfiguration;
public class main
{
public static Session session,oracleSession;
public static SessionFactory sessionFactory,oracleSessionFactory;
public String INIT;
public String getINIT()
{
openSession();
return this.INIT;
}

public static void openSession()
{
try
{
//Hibernate Configuration
if(configuration == null)
{
configuration = new Configuration().configure("hibernate.cfg.xml");
}
if(sessionFactory == null || sessionFactory.isClosed())
{
sessionFactory = configuration.buildSessionFactory();
}

if(session == null || !session.isOpen())
{
session = sessionFactory.openSession();
Transaction tx= main.session.beginTransaction();
session.createSQLQuery("SET NAMES utf8").executeUpdate();
tx.commit();
}
}
catch(Exception ex){ex.printStackTrace();}
}
}
其它javabean在使用数据库连接Session时,直接使用main.session即可。
例如Query query = main.session.getNamedQuery("you sql");

你需要在xhtml页面中放置#{main.INIT}代码,用以第一次调用main javabean。

针对mysql,你需要配置c3p0,但不需要修改上去代码。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值