-
Notifications
You must be signed in to change notification settings - Fork 45
/
APIJSONSQLExecutor.java
executable file
·111 lines (86 loc) · 4.17 KB
/
APIJSONSQLExecutor.java
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
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
/*Copyright ©2016 TommyLemon(https://github.com/TommyLemon/APIJSON)
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.*/
package apijson.framework;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.SQLException;
import java.util.Map;
import apijson.column.ColumnUtil;
import org.postgresql.util.PGobject;
import com.alibaba.fastjson.JSONObject;
import apijson.JSON;
import apijson.Log;
import apijson.NotNull;
import apijson.orm.AbstractSQLExecutor;
import apijson.orm.SQLConfig;
/**executor for query(read) or update(write) MySQL database
* @author Lemon
*/
public class APIJSONSQLExecutor<T extends Object> extends AbstractSQLExecutor<T> {
public static final String TAG = "APIJSONSQLExecutor";
static {
try { //加载驱动程序
Log.d(TAG, "尝试加载 MySQL 8 驱动 <<<<<<<<<<<<<<<<<<<<< ");
Class.forName("com.mysql.cj.jdbc.Driver");
Log.d(TAG, "成功加载 MySQL 8 驱动!>>>>>>>>>>>>>>>>>>>>>");
}
catch (ClassNotFoundException e) {
Log.e(TAG, "加载 MySQL 8 驱动失败,请检查 pom.xml 中 mysql-connector-java 版本是否存在以及可用 !!!");
e.printStackTrace();
try { //加载驱动程序
Log.d(TAG, "尝试加载 MySQL 7 及以下版本的 驱动 <<<<<<<<<<<<<<<<<<<<< ");
Class.forName("com.mysql.jdbc.Driver");
Log.d(TAG, "成功加载 MySQL 7 及以下版本的 驱动!>>>>>>>>>>>>>>>>>>>>> ");
}
catch (ClassNotFoundException e2) {
Log.e(TAG, "加载 MySQL 7 及以下版本的 驱动失败,请检查 pom.xml 中 mysql-connector-java 版本是否存在以及可用 !!!");
e2.printStackTrace();
}
}
try { //加载驱动程序
Log.d(TAG, "尝试加载 PostgresSQL 驱动 <<<<<<<<<<<<<<<<<<<<< ");
Class.forName("org.postgresql.Driver");
Log.d(TAG, "成功加载 PostgresSQL 驱动!>>>>>>>>>>>>>>>>>>>>> ");
}
catch (ClassNotFoundException e) {
e.printStackTrace();
Log.e(TAG, "加载 PostgresSQL 驱动失败,请检查 libs 目录中 postgresql.jar 版本是否存在以及可用 !!!");
}
}
@Override
public PreparedStatement setArgument(@NotNull SQLConfig<T> config, @NotNull PreparedStatement statement, int index, Object value) throws SQLException {
if (config.isPostgreSQL() && JSON.isBooleanOrNumberOrString(value) == false) {
PGobject o = new PGobject();
o.setType("jsonb");
o.setValue(value == null ? null : value.toString());
statement.setObject(index + 1, o); //PostgreSQL 除了基本类型,其它的必须通过 PGobject 设置进去,否则 jsonb = varchar 等报错
return statement;
}
return super.setArgument(config, statement, index, value);
}
@Override
protected Object getValue(SQLConfig<T> config, ResultSet rs, ResultSetMetaData rsmd, int tablePosition,
JSONObject table, int columnIndex, String lable, Map<String, JSONObject> childMap) throws Exception {
Object value = super.getValue(config, rs, rsmd, tablePosition, table, columnIndex, lable, childMap);
return value instanceof PGobject ? JSON.parse(((PGobject) value).getValue()) : value;
}
// 支持 !key 反选字段 和 字段名映射,依赖插件 https://github.com/APIJSON/apijson-column
@Override
protected String getKey(SQLConfig<T> config, ResultSet rs, ResultSetMetaData rsmd, int tablePosition, JSONObject table,
int columnIndex, Map<String, JSONObject> childMap) throws Exception {
String key = super.getKey(config, rs, rsmd, tablePosition, table, columnIndex, childMap);
if (APIJSONSQLConfig.ENABLE_COLUMN_CONFIG) {
return ColumnUtil.compatOutputKey(key, config.getTable(), config.getMethod());
}
return key;
}
}