是的,真的是那个不好用的ibatis,不是好用的mybatis。
 
ASP站长网由于工作需要用到ibatis需要自己搭建环境,遇到了不少的坑,做一下记录。
 
一、环境配置
•Maven
•JDK1.6 (非常重要,使用SimpleDataSource作为数据源会在JDK1.8 会触发 not suitable driver found 异常,具体原因另外博文进行解析)
•MySQL 5.6
 
二、Maven依赖配置
 
   1.引入ibatis-sqlmap
 
        <dependency>
            <groupId>org.apache.ibatis</groupId>
            <artifactId>ibatis-sqlmap</artifactId>
            <version>2.3.4.726</version>
        </dependency>
 
   2.引入spring (spring-orm 是spring集成ibatis的关键所在)
 
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-orm</artifactId>
            <version>3.0.5.RELEASE</version>
        </dependency>
 
  3.引入spring aop以对事务进行管理
 
 
 
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-aop</artifactId>
            <version>3.0.5.RELEASE</version>
        </dependency>
 
        <dependency>
            <groupId>org.aspectj</groupId>
            <artifactId>aspectjrt</artifactId>
            <version>1.5.4</version>
        </dependency>
 
        <dependency>
            <groupId>org.aspectj</groupId>
            <artifactId>aspectjweaver</artifactId>
            <version>1.5.4</version>
        </dependency>
 
 
 
  完整的pom.xml文件
 
 
 
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
 
    <groupId>com.kwj</groupId>
    <artifactId>firstibatis</artifactId>
    <version>1.0-SNAPSHOT</version>
 
    <dependencies>
        <dependency>
            <groupId>org.apache.ibatis</groupId>
            <artifactId>ibatis-sqlmap</artifactId>
            <version>2.3.4.726</version>
        </dependency>
 
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-Java</artifactId>
            <version>5.1.14</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-orm</artifactId>
            <version>3.0.5.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-aop</artifactId>
            <version>3.0.5.RELEASE</version>
        </dependency>
 
        <dependency>
            <groupId>org.aspectj</groupId>
            <artifactId>aspectjrt</artifactId>
            <version>1.5.4</version>
        </dependency>
 
        <dependency>
            <groupId>org.aspectj</groupId>
            <artifactId>aspectjweaver</artifactId>
            <version>1.5.4</version>
        </dependency>
 
    </dependencies>
</project>
 
 
 
 
 
三.Spring 配置
 
application.xml 文件,注意SqlMapClient以及SqlMapClientTemplate
 
 
 
<?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:p="http://www.springframework.org/schema/p"
      xmlns:context="http://www.springframework.org/schema/context"
      xmlns:tx="http://www.springframework.org/schema/tx"
      xmlns:aop="http://www.springframework.org/schema/aop"
      xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
                http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-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">
 
    <!-- 使用Spring提供的数据库连接池 -->
    <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
        <property name="driverClassName" value="com.mysql.jdbc.Driver"/>
        <property name="username" value="root"/>
        <property name="password" value="123456"/>
        <property name="url" value="jdbc:mysql://localhost:3306/test"/>
    </bean>
 
    <!-- 事务管理器 -->
    <bean id="transactionManager"
          class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name="dataSource" ref="dataSource"/> <!--注入DataSource以对事务进行管理-->
    </bean>
 
    <!-- 使用Spring提供的SqlMapClient -->
    <bean id="sqlMapClient" class="org.springframework.orm.ibatis.SqlMapClientFactoryBean">
        <property name="configLocation" value="classpath:SqlMapConfig.xml"/> <!-- 指定ibatis的配置文件路径 -->
        <property name="dataSource" ref="dataSource"/> <!-- 注入数据源 -->
    </bean>
 
    <!-- SqlMapClientTemplate 将被注入到需要与数据库进行交互的地方 -->
    <bean id="sqlMapClientTemplate" class="org.springframework.orm.ibatis.SqlMapClientTemplate">
        <constructor-arg ref="sqlMapClient" />
    </bean>
 
    <!-- 定义事务管理器 -->
    <tx:advice id="txAdvice" transaction-manager="transactionManager">
        <tx:attributes>
            <tx:method name="get*" read-only="true"/>
            <tx:method name="delete*" rollback-for="Exception"
                      propagation="REQUIRED" isolation="READ_COMMITTED" />
            <tx:method name="update*" rollback-for="Exception"
                      propagation="REQUIRED" isolation="READ_COMMITTED"/>
            <tx:method name="remove*" rollback-for="Exception" isolation="READ_COMMITTED"/>
            <tx:method name="count*" read-only="true"/>
        </tx:attributes>
    </tx:advice>
 
    <aop:config>
        <!-- 定义切点,由于该包下皆为接口类,因此对于符合条件的类,Spring将采取JDK动态代理的方式实现AOP功能 -->
        <!-- 对于未实现接口的类需要使用CGLib 如果未引入依赖则会抛出异常 -->
        <aop:pointcut id="daoMethod" expression="execution(public * service.*.*(..))"/>
        <aop:advisor advice-ref="txAdvice" pointcut-ref="daoMethod"/>
    </aop:config>
 
    <!-- 开启包扫描 -->
    <context:component-scan base-package="service.impl;dao"/>
</beans>
 
 
 
 
 
四.ibatis 配置
 
SqlMapConfig.xml 文件
 
 
 
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE sqlMapConfig
        PUBLIC "-//ibatis.apache.org//DTD SQL Map Config 2.0//EN"
        "http://ibatis.apache.org/dtd/sql-map-config-2.dtd">
<sqlMapConfig>
    <!-- 指定SqlMap映射文件的路径 -->
    <sqlMap resource="mapper/User.xml" />
</sqlMapConfig>
 
 
 
 
 
mapper/User.xml 文件 (users表的中就id和name字段,其中id为自增长字段)
 
 
 
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE sqlMap
        PUBLIC "-//ibatis.apache.org//DTD SQL Map 2.0//EN"
        "http://ibatis.apache.org/dtd/sql-map-2.dtd">
<sqlMap>
    <typeAlias alias="bean.User" type="bean.User" />
    <select id="getAllUsers" resultClass="bean.User">
        select * from users
    </select>
 
    <select id="getUserListById" parameterClass="bean.User" resultClass="bean.User">
        select * from users
    </select>
 
    <update id="updateUser" parameterClass="bean.User">
        update users set `name` = #name# where id = #id#
    </update>
 
    <insert id="insertUser" parameterClass="bean.User">
        insert users(name) values(#name#)
    </insert>
</sqlMap>
 
 
 
 
 
五、代码
 
bean.User
 
 
 
 
package bean;
 
public class User {
    private Integer id;
    private String name;
 
    public Integer getId() {
        return id;
    }
 
    public void setId(Integer id) {
        this.id = id;
    }
 
    public String getName() {
        return name;
    }
 
    public void setName(String name) {
        this.name = name;
    }
 
    @Override
    public String toString() {
        return "[id:"+id+",name:"+name+"]";
    }
}
 
 
 
 
 
UserDaoImpl  (接口就不放了)
 
 
 
 
package dao.impl;
 
import bean.User;
import dao.UserDAO;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.orm.ibatis.SqlMapClientTemplate;
import org.springframework.stereotype.Component;
 
@Component
public class UserDAOImpl implements UserDAO {
 
    @Autowired
    private SqlMapClientTemplate sqlMapClientTemplate;
 
    public int updateUser(User user){
        return sqlMapClientTemplate.update("updateUser",user);
    }
 
}
 
 
 
 
 
UserServiceImpl (接口自行定义,该类的代码主要对Spring的事务回滚机制进行测试)
 
 
 
 
package service.impl;
import bean.User;
import dao.UserDAO;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import service.UserService;
 
@Service
public class UserServiceImpl implements UserService {
 
    @Autowired
    private UserDAO userDAO;
 
    public int updateUser(User user){
        if(user == null){
            return 0;
        }
        return userDAO.updateUser(user);
    }
 
    public int updateUser(User user, boolean triggerException) {
        if(user == null){
            return 0;
        }
        int result = userDAO.updateUser(user);
        if(triggerException){
            throw new RuntimeException("触发异常,检查是否回滚");
        }
        return result;
    }
}
 
 
 
Main
 
 
 
 
import bean.User;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import service.UserService;
 
public class SpringMain {
 
    public static void main(String[] args){
        ApplicationContext context =
                new ClassPathXmlApplicationContext("classpath:application.xml");
        UserService userService = (UserService) context.getBean(UserService.class);
        User user = new User();
        user.setId(1);
        String newName = "NewData:"+System.currentTimeMillis();
        user.setName(newName);
        userService.updateUser(user);
    }
}

dawei

【声明】:九江站长网内容转载自互联网,其相关言论仅代表作者个人观点绝非权威,不代表本站立场。如您发现内容存在版权问题,请提交相关链接至邮箱:bqsm@foxmail.com,我们将及时予以处理。