com.mars.mj.helper.templete.BaseJdbcTemplete Maven / Gradle / Ivy
package com.mars.mj.helper.templete;
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONObject;
import com.mars.core.constant.MarsSpace;
import com.mars.core.util.ThreadUtil;
import com.mars.mj.helper.base.DBHelper;
import com.mars.mj.manager.ConnectionManager;
import com.mars.mj.model.SqlBuilderModel;
import java.sql.Connection;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
/**
* jdbc模板父类
*/
public class BaseJdbcTemplete {
private static MarsSpace marsSpace = MarsSpace.getEasySpace();
/**
* 获取数据库连接
*
* @return
* @throws Exception
*/
protected static ConnectionManager getConnection(String dataSourceName) throws Exception {
ConnectionManager connectionManager = new ConnectionManager();
/* 获取当前线程中的Connection */
Object obj = marsSpace.getAttr(ThreadUtil.getThreadIdToTraction());
/* 获取数据源名称 */
String dataSourceName2 = getDataSourceName(dataSourceName);
if (obj != null) {
Map connections = (Map) obj;
connectionManager.setConnection(connections.get(dataSourceName2));
connectionManager.setHasTrantion(false);
} else {
connectionManager.setConnection(DBHelper.getConnection(dataSourceName2));
connectionManager.setHasTrantion(true);
}
return connectionManager;
}
/**
* 获取数据源名称
*
* @return str
*/
protected static String getDataSourceName(String dataSourceName) {
if (dataSourceName == null) {
dataSourceName = marsSpace.getAttr("defaultDataSource").toString();
}
return dataSourceName;
}
/**
* 构建sql语句
*
* @param sql
* @param args
* @return
* @throws Exception
*/
protected static SqlBuilderModel builderSql(String sql, Object args) throws Exception {
SqlBuilderModel sqlBuilderModel = new SqlBuilderModel();
JSONObject jsonObject = JSONObject.parseObject(JSON.toJSONString(args));
List
© 2015 - 2025 Weber Informatics LLC | Privacy Policy