spring+ibatis的公有DAO

这里用到的配置在这篇http://blog.csdn.net/sskicgah/article/details/11651877里,这个公有的DAO也很简单,主要是继承了spring的SqlMapClientDaoSupport

public class BaseDao extends SqlMapClientDaoSupport {
    @Resource(name = "sqlMapClient")
    private SqlMapClient sqlMapClient;

    @PostConstruct
    public void initSqlMapClient() {
        super.setSqlMapClient(sqlMapClient);
    }
}

下面是一个使用的例子,这里用到的是ibatis2.X的版本,不是mybatis3.X的版本

@Service("TestDaoImpl")
public class TestInfoDaoImpl extends BaseDao implements TestDao {

    public void deleteTestInfo(Map<String, Object> index) {
        this.getSqlMapClientTemplate().delete("deleteTestInfo", index);
    }

    public void insertTestInfo(TestInfo instance) {
        this.getSqlMapClientTemplate().insert("insertTestInfo", instance);
    }

    public List selectTestInfos(Map<String, Object> index) {
        return this.getSqlMapClientTemplate().queryForList("selectTestInfos",
                index);
    }
    // 查询条数
    public int selectTestInfosCount(<String, Object> index) {
        return (Integer) this.getSqlMapClientTemplate().queryForObject(
                "selectTestInfosCount", index);
    }

    public void updateTestInfo(Map<String, Object> index) {
        this.getSqlMapClientTemplate().update("updateTestInfo", index);
    }
    // ibatis自带的分页,查出结果集后再截取需要的记录
    public List selectTestInfos(Map<String, Object> index, int startrow, int pagesize) {
        return this.getSqlMapClientTemplate().queryForList("selectTestInfos",
                index, startrow, pagesize);
    }
    // 批量删除,批量操作,只要把executor.delete("deleteTestInfo", locallist.get(i))换为对应的写法就可以了。
    // 比如executor.insert("insertTestInfo", locallist.get(i))就是批量插入了。
    public void deleteTestInfos(List<Map<String, Object>> indexs) {
        final List<Map<String, Object>> locallist = indexs;
        getSqlMapClientTemplate().execute(new SqlMapClientCallback<Object>() {
            public Object doInSqlMapClient(SqlMapExecutor executor)
                throws SQLException {
                executor.startBatch();
                for (int i = 0, count = locallist.size(); i < count; i++) {
                    executor.delete("deleteTestInfo", locallist.get(i));
                    if ((i + 1) % Constants.BATCH_DEAL_NUM == 0) { // 分批Batch,Constants.BATCH_DEAL_NUM为批量提交的条数
                           executor.executeBatch();
                       executor.startBatch();
                    }
                }
                executor.executeBatch();
                return null;
            }
        });
    }
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值