OpenSqlRingsServiceImpl.java
2.96 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
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);
//        }
    }
}