Commit 5196c90c371efc4e4cbb8ceadde0c1a287e5ebf1
1 parent
11b49b02
Exists in
master
Alteração do mecanismo de atualização da classe executeSQL
Showing
3 changed files
with
69 additions
and
6 deletions
Show diff stats
cit-esi-api/src/main/java/br/com/centralit/esi/api/data/core/DataObjectUtil.java
| ... | ... | @@ -167,7 +167,10 @@ public final class DataObjectUtil { |
| 167 | 167 | } |
| 168 | 168 | } |
| 169 | 169 | |
| 170 | - DataColumn dataColumn = dataObject.getColumn(arg); | |
| 170 | + DataColumn dataColumn = null; | |
| 171 | + if (dataObject != null) { | |
| 172 | + dataColumn = dataObject.getColumn(arg); | |
| 173 | + } | |
| 171 | 174 | if (dataColumn == null) { |
| 172 | 175 | dataColumn = new DataColumn(arg, new DataType(javaClass)); |
| 173 | 176 | } | ... | ... |
cit-esi-api/src/main/java/br/com/centralit/esi/api/design/model/connector/DatabaseSql.java
| ... | ... | @@ -59,12 +59,12 @@ public class DatabaseSql extends Activity { |
| 59 | 59 | @JsonView({ Views.GenericView.class}) |
| 60 | 60 | private String returnSqlVariable; |
| 61 | 61 | |
| 62 | - @FlowElementProperty(tab=1, title="Variável de lista para várias operações SQL", type=PropertyElementTypeEnum.TEXT, maxLength=120) | |
| 62 | + @FlowElementProperty(tab=1, title="Variável de lista para várias operações SQL", type=PropertyElementTypeEnum.VARIABLE_NAME, maxLength=120) | |
| 63 | 63 | @Column(nullable = true, length=120) |
| 64 | 64 | @JsonView({ Views.GenericView.class}) |
| 65 | 65 | private String listSqlVariable; |
| 66 | 66 | |
| 67 | - @FlowElementProperty(tab=1, title="Variável de um bean usado pra substituir valores no SQL", type=PropertyElementTypeEnum.TEXT, maxLength=120) | |
| 67 | + @FlowElementProperty(tab=1, title="Variável do objeto usado pra substituir valores no SQL", type=PropertyElementTypeEnum.VARIABLE_NAME, maxLength=120) | |
| 68 | 68 | @Column(nullable = true, length=120) |
| 69 | 69 | @JsonView({ Views.GenericView.class}) |
| 70 | 70 | private String beanName; | ... | ... |
cit-esi-api/src/main/java/br/com/centralit/esi/api/execution/component/ExecuteSql.java
| ... | ... | @@ -16,11 +16,14 @@ import org.apache.commons.lang.text.StrSubstitutor; |
| 16 | 16 | import org.json.JSONArray; |
| 17 | 17 | import org.json.JSONObject; |
| 18 | 18 | |
| 19 | +import br.com.centralit.esi.api.data.core.DataObjectUtil; | |
| 19 | 20 | import br.com.centralit.esi.api.enumerated.SqlClauseTypeEnum; |
| 20 | 21 | import br.com.centralit.esi.api.runtime.RuntimeEnvironment; |
| 22 | +import br.com.centralit.esi.exception.EsiBusinessException; | |
| 21 | 23 | import br.com.centralit.esi.exception.EsiExecutionException; |
| 22 | 24 | |
| 23 | 25 | public class ExecuteSql { |
| 26 | + | |
| 24 | 27 | public static void execute(RuntimeEnvironment runtimeEnvironment) { |
| 25 | 28 | String connName = (String) runtimeEnvironment.getObject("CONNECTIONNAME"); |
| 26 | 29 | String sql = (String) runtimeEnvironment.getObject("SQLCONTENT"); |
| ... | ... | @@ -41,6 +44,7 @@ public class ExecuteSql { |
| 41 | 44 | } |
| 42 | 45 | runtimeEnvironment.addOrUpdateObject(nameResultSql, saida); |
| 43 | 46 | } |
| 47 | + | |
| 44 | 48 | public static Object executaSelect(Connection connection, RuntimeEnvironment runtimeEnvironment, String sqlQuery) { |
| 45 | 49 | Object saida = null; |
| 46 | 50 | try { |
| ... | ... | @@ -64,8 +68,9 @@ public class ExecuteSql { |
| 64 | 68 | } |
| 65 | 69 | return saida; |
| 66 | 70 | } |
| 71 | + | |
| 67 | 72 | @SuppressWarnings("rawtypes") |
| 68 | - public static String executaUpdate(Connection connection, RuntimeEnvironment runtimeEnvironment, String sqlUpdate) { | |
| 73 | + public static Object executaUpdate(Connection connection, RuntimeEnvironment runtimeEnvironment, String sqlUpdate) { | |
| 69 | 74 | String listNameForEach = (String) runtimeEnvironment.getObject("LISTFOREACH"); |
| 70 | 75 | String nameBeanSubt = (String) runtimeEnvironment.getObject("NAMEBEANSUBST"); |
| 71 | 76 | Object beanObj = null; |
| ... | ... | @@ -87,10 +92,61 @@ public class ExecuteSql { |
| 87 | 92 | } |
| 88 | 93 | return retorno; |
| 89 | 94 | }else{ |
| 90 | - String sqlAjustado = preparaSqlUpdate(connection, runtimeEnvironment, sqlUpdate, null, beanObj); | |
| 91 | - return executaSqlUpdate(connection, runtimeEnvironment, sqlAjustado); | |
| 95 | + HashMap<String, Object> map = buildParams(null, beanObj); | |
| 96 | + try { | |
| 97 | + DataObjectUtil.executeSQL(null, connection, sqlUpdate, map); | |
| 98 | + } catch (SQLException e) { | |
| 99 | + e.printStackTrace(); | |
| 100 | + throw new EsiBusinessException(e); | |
| 101 | + } | |
| 102 | + | |
| 103 | + return map; | |
| 104 | + } | |
| 105 | + } | |
| 106 | + | |
| 107 | + @SuppressWarnings({ "unchecked" }) | |
| 108 | + public static HashMap<String, Object> buildParams(Object bean, Object beanSubt2) { | |
| 109 | + HashMap<String, Object> valuesMapFinal = new HashMap<String, Object>(); | |
| 110 | + if (bean != null){ | |
| 111 | + try { | |
| 112 | + Map<String, Object> valuesMap = null; | |
| 113 | + valuesMap = PropertyUtils.describe(bean); | |
| 114 | + if (valuesMap != null){ | |
| 115 | + valuesMapFinal.putAll(valuesMap); | |
| 116 | + } | |
| 117 | + } catch (IllegalAccessException e) { | |
| 118 | + e.printStackTrace(); | |
| 119 | + throw new EsiExecutionException(e); | |
| 120 | + } catch (InvocationTargetException e) { | |
| 121 | + e.printStackTrace(); | |
| 122 | + throw new EsiExecutionException(e); | |
| 123 | + } catch (NoSuchMethodException e) { | |
| 124 | + e.printStackTrace(); | |
| 125 | + throw new EsiExecutionException(e); | |
| 126 | + } | |
| 92 | 127 | } |
| 128 | + if (beanSubt2 != null){ | |
| 129 | + try { | |
| 130 | + Map<String, Object> valuesMap = null; | |
| 131 | + valuesMap = PropertyUtils.describe(beanSubt2); | |
| 132 | + if (valuesMap != null){ | |
| 133 | + valuesMapFinal.putAll(valuesMap); | |
| 134 | + } | |
| 135 | + } catch (IllegalAccessException e) { | |
| 136 | + e.printStackTrace(); | |
| 137 | + throw new EsiExecutionException(e); | |
| 138 | + } catch (InvocationTargetException e) { | |
| 139 | + e.printStackTrace(); | |
| 140 | + throw new EsiExecutionException(e); | |
| 141 | + } catch (NoSuchMethodException e) { | |
| 142 | + e.printStackTrace(); | |
| 143 | + throw new EsiExecutionException(e); | |
| 144 | + } | |
| 145 | + } | |
| 146 | + | |
| 147 | + return valuesMapFinal; | |
| 93 | 148 | } |
| 149 | + | |
| 94 | 150 | @SuppressWarnings({ "unchecked", "unused" }) |
| 95 | 151 | public static String preparaSqlUpdate(Connection connection, RuntimeEnvironment runtimeEnvironment, String sqlUpdate, Object bean, Object beanSubt2) { |
| 96 | 152 | Map<String, Object> valuesMapFinal = new HashMap<String, Object>(); |
| ... | ... | @@ -138,6 +194,7 @@ public class ExecuteSql { |
| 138 | 194 | return sqlUpdate; |
| 139 | 195 | } |
| 140 | 196 | } |
| 197 | + | |
| 141 | 198 | public static String executaSqlUpdate(Connection connection, RuntimeEnvironment runtimeEnvironment, String sqlUpdate) { |
| 142 | 199 | int resQtde = 0; |
| 143 | 200 | try { |
| ... | ... | @@ -161,6 +218,7 @@ public class ExecuteSql { |
| 161 | 218 | } |
| 162 | 219 | return "{\"count\":\"" + resQtde + "\"}"; |
| 163 | 220 | } |
| 221 | + | |
| 164 | 222 | public static Object geraSaidaSelect(ResultSet result, RuntimeEnvironment runtimeEnvironment) throws SQLException { |
| 165 | 223 | String tipoSaida = (String) runtimeEnvironment.getObject("OUTPUT"); |
| 166 | 224 | if (tipoSaida == null){ |
| ... | ... | @@ -173,6 +231,7 @@ public class ExecuteSql { |
| 173 | 231 | } |
| 174 | 232 | return ""; |
| 175 | 233 | } |
| 234 | + | |
| 176 | 235 | public static JSONArray geraSaidaSelectJSON(ResultSet result, RuntimeEnvironment runtimeEnvironment) throws SQLException { |
| 177 | 236 | JSONArray jsonArray = new JSONArray(); |
| 178 | 237 | |
| ... | ... | @@ -190,6 +249,7 @@ public class ExecuteSql { |
| 190 | 249 | |
| 191 | 250 | return jsonArray; |
| 192 | 251 | } |
| 252 | + | |
| 193 | 253 | public static List<Object> geraSaidaSelectLIST(ResultSet result, RuntimeEnvironment runtimeEnvironment) throws SQLException { |
| 194 | 254 | ResultSetMetaData metaData = result.getMetaData(); |
| 195 | 255 | int columnCount = metaData.getColumnCount(); | ... | ... |