`
NanguoCoffee
  • 浏览: 51699 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

JForum源码学习研究3-持久层

阅读更多

ps: 图片怎么添加到blog 中呀???

 

1:数据库配置
在SystemGlobals.property中会看到这么一块信息:
# Database type to use
database.driver.name = mysql

# Can be net.jforum.SimpleConnection, net.jforum.PooledConnection
# or net.jforum.DataSourceConnection
database.connection.implementation = net.jforum.PooledConnection

# Enable / Disable transactions
database.use.transactions = true

# DataSource name, in case of using net.jforum.core.db.DataSourceConnection
database.datasource.name = java:/MySqlDS

# Time in seconds to healthcheck all database connections
database.ping.delay = 3600

# Extra parameters to pass to C3P0 (only when using PooledConnection)
# Form is key=value;key2=value2;keyN=valueN
c3p0.extra.params = checkoutTimeout=120000;debugUnreturnedConnectionStackTraces=false;unreturnedConnectionTimeout=180


这里配置了驱动类型,Connection的实现类,数据源等信息。
在论坛启动的时候会加载这些数据:
database.driver.config = ${config.dir}/database/${database.driver.name}/${database.driver.name}.properties
sql.queries.driver = ${config.dir}/database/${database.driver.name}/${database.driver.name}.sql
sql.queries.generic = ${config.dir}/database/generic/generic_queries.sql

2:封装数据库连接及连接池

2.1 DBConnection接口

接口方法:
[img][/img]
public static boolean createInstance()
载入并初始化在SystemGlobals.properties中配置的
database.connection.implementation 的值。该值是一个DBConnection实现类。

2.2 DBConnection类层次:

针对数据库中
默认的实现的使用了C3P0连接池的连接。
SimpleConnection不使用连接池,每次使用都需要获取一次数据库连接。
C3P0PooledConnection使用ComboPooledDataSource 数据源来获取连接,数据源的配置信息是通过SystemGlobals.properties和位于/WEB-INF/config/database/{DB_Name}/{DB_Name}.properties来配置。


3: DAO设计


DataAccessDriver会根据配置文件来注入具体的DataAccessDriver实现类。默认是MysqlDataAccessDriver. 那么对应就使用MysqlForumDAO等DAO的实现类。
这是典型的工厂模式,好处很多。

4:DAO中方法的实现
在前面说过,JForum是将所有的查询SQL放到配置文件中。对数据库操作的时候,就将对应的sql语句读取出来。
看GenericForumDAO中的一个方法:
protected int countForumPosts(int forumId)
{ PreparedStatement p = null;
ResultSet rs = null;
try {
p = JForumExecutionContext.getConnection().prepareStatement(
SystemGlobals.getSql("ForumModel.countForumPosts"));
p.setInt(1, forumId);
rs = p.executeQuery();

if (rs.next()) {
return rs.getInt(1);
}

return 0;
}
catch (SQLException e) {
throw new DatabaseException(e);
}
finally {
DbUtils.close(rs, p);
}
}

5:Connection获取及关闭的处理
在上面DAO的方法中,我们看到Connection是通过
JForumExecutionContext来获取的。其实JForumExecutionContext就是通过DBConnection接口获取的。如果已经存在了一个Conneciton,就使用已存在的,没有则新建。
在DAO方法中,我们看到只获取了Connection对象,数据库操作完毕后并没有执行conn.close()操作。
JForum是针对一个线程一个Connection,使用ThreadLocal对象将
JForumExecutionContext对象放入当前执行的线程中。
JForumExecutionContext中有finish()方法是用来处理操作结束时资源的清理,主要就是connection。
查看finish()被调用的地方,我们会发现,在执行完一段代码后会在finally块中执行JForumExecutionContext.finish()来释放数据库连接;

 

 

分享到:
评论

相关推荐

    jforum 源码

    JForum使用Hibernate作为持久层框架,进行数据库操作。源码中可以学习到如何使用Hibernate的Session和Transaction进行数据增删改查,以及如何通过ORM(对象关系映射)将Java对象与数据库表关联。 4. **安全机制** ...

    开源BBS--JForum 源码

    10. 数据库访问:JForum使用Hibernate作为持久层框架,简化了数据库操作,提高了开发效率。 学习JForum的源码,你不仅可以掌握Java Web开发的基本技巧,还能了解到如何设计一个大型的、可扩展的论坛系统。这对你...

    JForum3 完整项目

    3. **Hibernate**:作为持久层框架,负责数据库操作,提供对象关系映射(ORM)功能。 4. **Spring Framework**:提供依赖注入(DI)、AOP(面向切面编程)等,简化了应用开发和管理。 5. **Apache Velocity**:...

    java开源论坛jforum

    Java开源论坛JForum是一款基于Java开发的讨论区平台,它为开发者提供了一个高效、功能...通过对JForum的源码学习,开发者可以掌握更多关于Web应用设计和实现的实用技巧,对于个人技术成长和职业发展都有着积极的影响。

    使用Sakai构建开放式教学平台(完整版)

    其目标明确而远大——打造一款能够替代现有商业课程管理系统的通用平台,旨在促进教学、学习以及学术研究中的协作与创新。Sakai不仅支持全面或部分在线的学习环境,还具备高度的灵活性和可定制性,能够适应不同教育...

    2009系统架构师大会PPT:李江涛:使用Sakai构建开放式教学平台

    - **技术栈开放性**:Sakai基于一系列开放的技术栈构建,如Linux/Windows/Mac操作系统、Apache Tomcat服务器、MySQL/Oracle数据库、Hibernate持久层框架、Spring框架、以及多种前端技术(JSF/RSF/JSP/Velocity/...

Global site tag (gtag.js) - Google Analytics