blob: e2774e26505d449cc41b1ba762ee4956bb19e9ff (
plain)
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
|
/**
*
*
*/
package com.nis.util;
import cn.hutool.core.util.StrUtil;
import cn.hutool.log.Log;
import org.apache.ibatis.mapping.DatabaseIdProvider;
import com.nis.entity.AssetBrand;
import com.nis.entity.AssetTypeConf;
import com.nis.entity.SysDictEntity;
import javax.sql.DataSource;
import java.sql.Connection;
import java.sql.DatabaseMetaData;
import java.sql.SQLException;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
/**
* 常量
*
*/
public class Constant {
private final static Log logger = Log.get();
public static Boolean rollBack = false;
/**
* 当前数据库类型
*/
public static final String DB_TYPE;
public static final String DATABASE_NAME;
public static final String ORACLE = "oracle";
public static final String MYSQL = "mysql";
public static final String POSTGRESQL = "postgresql";
static {
DatabaseIdProvider databaseIdProvider = SpringContextUtils.getBean("getDatabaseIdProvider", DatabaseIdProvider.class);
DataSource dataSource = SpringContextUtils.getBean("dataSource",DataSource.class);
String databaseId = null;
String databaseName=null;
try {
databaseId = databaseIdProvider.getDatabaseId(dataSource);
Connection connection = dataSource.getConnection();
DatabaseMetaData metaData = connection.getMetaData();
String url = metaData.getURL();
if(StrUtil.isNotBlank(url)) {
String[] split = StrUtil.split(url, "?");
databaseName = StrUtil.subAfter(split[0], "/", true);
}
} catch (SQLException e) {
logger.error(e);
}
DB_TYPE = databaseId;
DATABASE_NAME = databaseName;
}
public static Map<Integer,AssetBrand> assetBrands = new HashMap<Integer,AssetBrand>();
}
|