|
39 | 39 | import org.slf4j.Logger;
|
40 | 40 | import org.slf4j.LoggerFactory;
|
41 | 41 |
|
| 42 | +import java.math.BigDecimal; |
42 | 43 | import java.sql.Timestamp;
|
| 44 | +import java.time.Instant; |
43 | 45 | import java.util.Date;
|
44 | 46 | import java.util.List;
|
45 | 47 | import java.util.Map;
|
@@ -87,7 +89,7 @@ public void asyncInvoke(Row input, ResultFuture<Row> resultFuture) throws Except
|
87 | 89 | dealMissKey(inputRow, resultFuture);
|
88 | 90 | return;
|
89 | 91 | }
|
90 |
| - inputParams.add(convertDateType(equalObj)); |
| 92 | + inputParams.add(convertDataType(equalObj)); |
91 | 93 | }
|
92 | 94 |
|
93 | 95 | String key = buildCacheKey(inputParams);
|
@@ -151,15 +153,43 @@ public void asyncInvoke(Row input, ResultFuture<Row> resultFuture) throws Except
|
151 | 153 | });
|
152 | 154 | }
|
153 | 155 |
|
154 |
| - private Object convertDateType(Object val) { |
155 |
| - if (val instanceof Timestamp) { |
| 156 | + |
| 157 | + private Object convertDataType(Object val) { |
| 158 | + if (val == null) { |
| 159 | + // OK |
| 160 | + } else if (val instanceof Number && !(val instanceof BigDecimal)) { |
| 161 | + // OK |
| 162 | + } else if (val instanceof Boolean) { |
| 163 | + // OK |
| 164 | + } else if (val instanceof String) { |
| 165 | + // OK |
| 166 | + } else if (val instanceof Character) { |
| 167 | + // OK |
| 168 | + } else if (val instanceof CharSequence) { |
| 169 | + |
| 170 | + } else if (val instanceof JsonObject) { |
| 171 | + |
| 172 | + } else if (val instanceof JsonArray) { |
| 173 | + |
| 174 | + } else if (val instanceof Map) { |
| 175 | + |
| 176 | + } else if (val instanceof List) { |
| 177 | + |
| 178 | + } else if (val instanceof byte[]) { |
| 179 | + |
| 180 | + } else if (val instanceof Instant) { |
| 181 | + |
| 182 | + } else if (val instanceof Timestamp) { |
156 | 183 | val = DateUtil.getStringFromTimestamp((Timestamp) val);
|
157 |
| - } else if (val instanceof Date) { |
| 184 | + } else if (val instanceof java.util.Date) { |
158 | 185 | val = DateUtil.getStringFromDate((java.sql.Date) val);
|
| 186 | + } else { |
| 187 | + val = val.toString(); |
159 | 188 | }
|
160 | 189 | return val;
|
161 | 190 | }
|
162 | 191 |
|
| 192 | + |
163 | 193 | protected List<Row> getRows(Row inputRow, List<JsonArray> cacheContent, List<JsonArray> results) {
|
164 | 194 | List<Row> rowList = Lists.newArrayList();
|
165 | 195 | for (JsonArray line : results) {
|
|
0 commit comments