OpenSqlRingsServiceImpl.java 2.96 KB
package com.server.web.common.service.Impl;

import com.server.web.common.service.OpenSqlRingsService;
import org.mybatis.spring.SqlSessionTemplate;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.datasource.DataSourceTransactionManager;
import org.springframework.stereotype.Service;
import org.springframework.transaction.TransactionDefinition;
import org.springframework.transaction.TransactionStatus;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.transaction.support.DefaultTransactionDefinition;

import java.util.ArrayList;
import java.util.List;
import java.util.Map;

/**
 * 指环王工具
 * Created by yinbin on 2018/1/12.
 * 自定义sql执行工具类
 * 功能:通过sql的命名空间,指定执行xml里的sql
 * 1、增删改查
 * 2、批量增加
 */
@Service
public class OpenSqlRingsServiceImpl implements OpenSqlRingsService {

    @Autowired
    private SqlSessionTemplate sqlSession;

//    @Autowired
//    private DataSourceTransactionManager transactionManager;

    @Override
    public Object selectOne_Rings(String statement, Map<String, Object> params) {
        Object obj = sqlSession.selectOne(statement, params);
        return obj;
    }

    @Override
    public ArrayList<Object> selectList_Rings(String statement, Map<String, Object> params) {
        ArrayList<Object> resultList = (ArrayList<Object>) sqlSession.selectList(statement, params);
        return resultList;
    }

    @Override
    @Transactional
    public void insert_Rings(String statement, Map<String, Object> params) {
        sqlSession.insert(statement, params);
    }

    @Override
    @Transactional
    public void delete_Rings(String statement, Map<String, Object> params) {
        sqlSession.delete(statement, params);
    }

    @Override
    @Transactional
    public void update_Rings(String statement, Map<String, Object> params) {
        sqlSession.update(statement, params);
    }

    @Override
    @Transactional
    public void insert_batch_Rings(String statement, List<Map<String, Object>> params) {
        for (Map<String, Object> map : params) {
            sqlSession.insert(statement, map);
        }
    }


    @Override
    public void insert_batch11_Rings(String statement, List<Map<String, Object>> params, int per) {
//
//        //事物定义类
//        DefaultTransactionDefinition transactionDefinition = new DefaultTransactionDefinition(TransactionDefinition.PROPAGATION_REQUIRED);
//        //获取事物对象
//        TransactionStatus status = transactionManager.getTransaction(transactionDefinition);
//
//        try {
//            for (Map<String, Object> map : params) {
//                sqlSession.insert(statement, map);
//            }
//            //插入成功提交事物
//            transactionManager.commit(status);
//        } catch (Exception e) {
//            //异常回滚事物
//            transactionManager.rollback(status);
//        }
    }


}