ibatis 使用

1、SqlMapClientFactoryBean 的装配 
    SqlMapClientFactoryBean是SqlMapClientTemplate使用的基础,如果在 
    SpringFramework应用中没有装配SqlMapClientFactoryBean,那么SqlMapClientTemplate将不可用,报空指针错误。

    <bean id="sqlMapClient" class="org.springframework.orm.ibatis.SqlMapClientFactoryBean">
        <property name="configLocation" value="/WEB-INF/sqlmap-config.xml"/> <!-- iBatis sqlmap config 文件位置 -->
        <property name="dataSource" ref="dataSource"/> <!-- 在SpringFramework配置文件中使用的数据源 -->
        <property name="lobHandler" ref="oracleLobHandler"/> <!-- 如果需要读写Lob字段,需要注入在SpringFramework配置文件中配置好的Handler,这里是Oracle的数据库 -->
    </bean>

2、继承使用SqlMapClientDaoSupport类 
声明Java类:

import org.springframework.orm.ibatis.support.SqlMapClientDaoSupport;  
    ......  
    public class ReportDAOImpl extends SqlMapClientDaoSupport {  
        ......  
    }  

SpringFramework配置文件中装配Java类:

<bean id="reportDao" class="com.test.dao.ReportDAOImpl">  
        <property name="sqlMapClient" ref="sqlMapClient"/> <!-- 装配SqlMapClientFactoryBean -->  
    </bean>  

3、使用SqlMapClientTemplate查询 
Java代码: 
    当执行没有参数的查询时: 

    List result = getSqlMapClientTemplate().queryForList("TestSpace.qryTest");

 "TestSpace"为iBatis SqlMap文件的命名空间;"qryTest"为iBatis SqlMap的查询方法id 

当按照某些条件查询时:

ObjectA objA = new ObjectA();
    objA.setParam1("test1");
    objA.setParam2("test2");
    ......
    List result = getSqlMapClientTemplate().queryForList("TestSpace.qryTestByParam", objA);

如果需要取4~40条数据: 
    List result = getSqlMapClientTemplate().queryForList("TestSpace.qryTestByParam", objA, 4, 40); 

 

4、使用SqlMapClientTemplate添加数据 
Java代码: 
    ObjectA objA = new ObjectA(); 

 objA.setParam1("test1");
    objA.setParam2("test2");
    ......
    getSqlMapClientTemplate().insert("TestSpace.insertTest", objA);

5、使用SqlMapClientTemplate更新数据 
Java代码: 

ObjectA objA = new ObjectA();
    objA.setParam1("test1");
    objA.setParam2("test2");
    ......
    getSqlMapClientTemplate().update("TestSpace.updateTest", objA);

6、使用SqlMapClientTemplate删除数据 
Java代码:

Long id = new Long("2");
getSqlMapClientTemplate().delete("TestSpace.deleteTest", id);

 

posted @ 2015-09-01 18:01  燕萧云  阅读(209)  评论(0编辑  收藏  举报