`

转载:spring配置ibatis的jdbc方式和proxool、c3p0连接池方式

阅读更多
spring配置ibatis的jdbc方式和proxool连接池方式,以sqlserver2005为例,驱动为sqljdbc.jar
jdbc.properties中内容如下
jdbc.driverClassName=com.microsoft.sqlserver.jdbc.SQLServerDriver
jdbc.url=jdbc\:sqlserver\://localhost\:1433; DatabaseName\=IBATIS
jdbc.username=sa
jdbc.password=1234561
直接用jdbc方式(这种方式适合开发阶段,发布的程序强烈要求用连接池),代码如下,这个都知道,没什么可说的
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns:aop="http://www.springframework.org/schema/aop"
    xmlns:context="http://www.springframework.org/schema/context"
    xmlns:tx="http://www.springframework.org/schema/tx"
    xsi:schemaLocation="
       http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
       http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.5.xsd
       http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.5.xsd
       http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd">
    
    <context:component-scan base-package="com.mydomain">
        <context:include-filter type="aspectj" expression="com.mydomain.spring..*"/>
    </context:component-scan>
    <context:property-placeholder location="classpath:jdbc.properties" />
    <bean id="dataSource" 
        class="org.apache.commons.dbcp.BasicDataSource"
        destroy-method="close">
        <property name="driverClassName" value="${jdbc.driverClassName}" />
        <property name="url" value="${jdbc.url}" />
        <property name="username" value="${jdbc.username}" />
        <property name="password" value="${jdbc.password}" />
    </bean>

    <bean id="sqlMapClient" class="org.springframework.orm.ibatis.SqlMapClientFactoryBean">
        <property name="configLocation" value="classpath:com/mydomain/data/SqlMapConfig.xml"/>
        <property name="dataSource" ref="dataSource"/>
    </bean>
    <!--事务管理直接用的DataSourceTransactionManager-->
    <bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name="dataSource" ref="dataSource"/>
    </bean>
    <aop:config>
        <aop:pointcut id="baseServiceMethods"
            expression="execution(* com.mydomain.spring.*.*(..))" />
        <aop:advisor advice-ref="txAdvice"
            pointcut-ref="baseServiceMethods" />
    </aop:config>
    <aop:aspectj-autoproxy />
    <tx:advice id="txAdvice" transaction-manager="txManager">
        <tx:attributes>
            <tx:method name="select*" read-only="true" propagation="REQUIRED"/>
            <tx:method name="find*" read-only="true"  propagation="REQUIRED"/>
            <tx:method name="save*"  propagation="REQUIRED" isolation="REPEATABLE_READ"/>
            <tx:method name="update*"  propagation="REQUIRED" isolation="REPEATABLE_READ"/>
            <tx:method name="add*"  propagation="REQUIRED" isolation="REPEATABLE_READ" />
            <tx:method name="delete*"  propagation="REQUIRED" isolation="REPEATABLE_READ"/>
        </tx:attributes>
    </tx:advice>
</beans>
SqlMapConfig.xml内容如下:
<!DOCTYPE sqlMapConfig PUBLIC "-//iBATIS.com//DTD SQL Map Config 2.0//EN"
    "http://www.ibatis.com/dtd/sql-map-config-2.dtd">

<sqlMapConfig>
  <sqlMap resource="com/mydomain/data/Account.xml"/>
  
</sqlMapConfig>2 用proxool连接池方式,只有datasource发生变化,其他的无变动
  需要加入proxool.jar
    <bean id="dataSource" class="org.logicalcobwebs.proxool.ProxoolDataSource" destroy-method="close">
        <property name="alias" value="test"></property>
        <property name="delegateProperties">
            <value>user=${jdbc.username},password=${jdbc.password}</value>
        </property>
        <property name="user" value="${jdbc.username}"/>
        <property name="password" value="${jdbc.password}"/>
        <property name="driver" value="${jdbc.driverClassName}"/>
        <property name="driverUrl" value="${jdbc.url}"/>
        <property name="houseKeepingTestSql" value="select CURRENT_DATE"></property>
        <!--此处继续增加proxool属性,详细见proxool文档-->
    </bean>
此处说明一下:属性中的user和password不起任何作用,需要用delegateProperties方式写一下,否则会报错误,如下
    org.springframework.transaction.CannotCreateTransactionException: Could not open JDBC Connection for transaction; nested exception is com.microsoft.sqlserver.jdbc.SQLServerException: Login failed for user ''. The user is not associated with a trusted SQL Server connection.
但是user和password还不能被去掉。

除了上面的用delegateProperties之外,还可以将用户名和密码直接写在url后面。

proxool属性的说明,在这里写的比较详细
http://www.cnblogs.com/wllyy189/archive/2008/10/15/1311560.html
3 c3p0方式
  需要加入c3p0.jar
  
 <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close">
        <property name="driverClass">
                <value>${jdbc.driverClassName}</value>
            </property>
            <property name="jdbcUrl">
                <value>${jdbc.url}</value>
            </property>
            <property name="user">
                <value>${jdbc.username}</value>
            </property>
            <property name="password">
                <value>${jdbc.password}</value>
            </property>
            <!--此处继续增加c3p0属性-->
    </bean>

关于c3p0的属性说明请参见:
http://www.blogjava.net/Alpha/archive/2009/03/29/262789.html

分享到:
评论

相关推荐

    ibatis-2.3.0.677增加对c3p0连接池的支持

    标题 "ibatis-2.3.0.677增加对c3p0连接池的支持" 描述了MyBatis框架的一个更新,其中包含了对c3p0数据库连接池的集成。MyBatis是一个轻量级的Java持久层框架,它允许开发者将SQL语句直接嵌入到Java代码中,提供了比...

    在iBatis中加入c3p0数据库连接池

    本篇文章将详细讲解如何在iBatis中集成c3p0数据库连接池,以及c3p0的基本配置和使用。 iBatis是一个轻量级的持久层框架,它允许开发者将SQL语句直接写在配置文件中,方便灵活。而c3p0则是一个开源的JDBC连接池,它...

    webwork+ibatis+spring oracle c3p0 集成框架

    4. Oracle C3P0:C3P0 是一个开源的JDBC连接池,它提供了数据源管理和连接池服务。C3P0 可以帮助优化数据库连接的创建和释放,提高应用性能,同时提供了一套完善的连接池监控和配置选项,确保数据库资源的有效利用和...

    spring ibatis整合所需jar包

    在Java Web开发中,Spring和iBatis是两个非常重要的框架。Spring是一个全面的后端开发框架,提供了依赖注入、AOP(面向切面编程)、事务管理等特性,而iBatis则是一个优秀的持久层框架,它将SQL语句与Java代码分离,...

    Spring+ibatis 保留ibatis事务的配置

    根据提供的文件信息,本文将详细解析如何在Spring与ibatis框架整合时,通过特定配置来保留ibatis事务处理机制,并实现对事务的自定义控制。文章将围绕标题、描述及部分代码片段展开讨论。 ### Spring与ibatis整合...

    spring+ibatis事务的配置

    很好的spring+ibatis事务的配置文档.

    Struts2+Spring+Hibernate和Struts2+Spring+Ibatis

    在这个例子中,Ibatis的SqlMapConfig.xml文件将配置数据库连接和映射文件,Action类会调用Service层的方法,Service层通过Ibatis的SqlSession执行SQL。 整合这两个框架,开发者通常需要做以下工作: - 配置Struts2...

    spring+ibatis配置实例

    在IT行业中,Spring框架与iBatis(现为MyBatis)是两个广泛使用的开源库,主要用于构建企业级Java应用程序。...通过学习这个实例,开发者可以更好地理解Spring和iBatis的整合使用,提升开发效率和代码可维护性。

    spring+ibatis的项目需要的jar包

    3. commons-dbcp.jar 或 c3p0.jar:这些是数据库连接池的实现,用于高效管理数据库连接。 4. mybatis-spring.jar:这是Spring与iBatis之间的桥梁,提供了将iBatis SqlSessionTemplate和SqlSessionFactoryBean集成到...

    Spring+ibatis的jar包

    4. **数据源(DataSource)**:iBATIS 需要连接到数据库,因此需要配置数据源,可以是 JDBC 数据源或其他连接池实现。 5. **MyBatis**:iBATIS 后续发展为 MyBatis,增加了更多功能,如支持注解、更丰富的动态 SQL ...

    spring与ibatis整合集成实例

    3. **配置文件**:在整合过程中,需要配置两部分:Spring 配置文件(如 `applicationContext.xml`)和 iBATIS 配置文件(如 `sqlMapConfig.xml`)。Spring 配置文件中定义数据源、事务管理器以及 ...

    spring整合ibatis

    1. **引入依赖**:在项目中添加Spring和iBatis的相关依赖库,通常包括`spring-context`, `spring-jdbc`, `mybatis-spring`, 和 `mybatis`。 2. **配置数据源**:在Spring的配置文件中定义数据源,例如使用Apache ...

    Spring struts ibatis Mysql 集成

    在IT行业中,集成Spring、Struts和iBatis与MySQL是构建企业级Java Web应用程序的常见选择。这个项目集成了Spring 2.5.5、Struts 2.1.6、iBatis 2.3.4以及MySQL 5.1数据库,使用IntelliJ IDEA 9作为开发环境。下面将...

    spring+ibatis整合web所需ibatis包

    在IT行业中,Spring和iBatis的整合是常见的企业级应用开发模式,它结合了Spring的强大功能和iBatis的灵活数据库操作。本资源“spring+ibatis整合web所需ibatis包”提供的是用于实现这一整合的关键iBatis库,解决在...

    Spring与iBATIS的集成

    但正如Spring A Developer's Notebook作者Bruce Tate 和Justin Gehtland所说的那样,与其他的OR框架相比,iBATIS独辟蹊径“iBATIS不是试图从根本上掩盖SQL,实际上,它是在拥抱SQL。” &lt;br&gt;但别犯愁:SQL本身具备...

    proxool 连接池实例

    与C3P0、DBCP、HikariCP等其他连接池相比,Proxool在小型项目或测试环境中表现出色,尤其适合那些对资源管理和性能调整有特定需求的场景。 **二、Proxool的工作原理** Proxool维护了一个连接池,当应用程序需要...

    spring+ibatis所需要的jar包

    在Java开发领域,Spring和iBatis是两个非常重要的框架,它们分别负责应用程序的依赖管理和数据库操作。Spring是一个全面的后端开发框架,提供了一系列强大的功能,如依赖注入、AOP(面向切面编程)、MVC(模型-视图-...

    spring_ibatis整合案例

    首先,我们需要在项目中引入Spring和iBatis的依赖库,通常通过Maven或Gradle进行管理。Spring的核心库包含Spring Core、Spring Beans、Spring Context等,而iBatis(MyBatis)则需要其主库和Spring的适配器库。 3....

Global site tag (gtag.js) - Google Analytics