|
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