zoukankan      html  css  js  c++  java
  • 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);

  • 相关阅读:
    StrCopy、StrCat、StrPas
    WinAPI: FlashWindow 闪烁窗口
    WinAPI: SetVolumeLabel 设置磁盘卷标
    WinAPI: GetActiveWindow 获取当前活动窗口的句柄
    WinAPI: SetCurrentDirectory、GetCurrentDirectory 设置与获取当前目录
    WinAPI: CreateDirectoryEx 根据模版建立文件夹
    WinAPI: CreateDirectory 建立文件夹
    WinAPI: RemoveDirectory 删除空目录
    WinAPI: GetLogicalDriveStrings 获取系统中存在的逻辑驱动器字符串
    filer.js: 一个 Unix 命令风格的 HTML 5 FileSystem API 封装 V2EX
  • 原文地址:https://www.cnblogs.com/yinghao/p/4776446.html
Copyright © 2011-2022 走看看