
net.sf.aguacate.context.spi.sql.impl.SentenceSqlInsert Maven / Gradle / Ivy
package net.sf.aguacate.context.spi.sql.impl;
import java.sql.Connection;
import java.sql.SQLException;
import java.util.List;
import java.util.Map;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
import net.sf.aguacate.context.spi.sql.SentenceExecutionResult;
import net.sf.aguacate.context.spi.sql.SentenceSqlType;
import net.sf.aguacate.util.config.database.DatabaseInterface;
public class SentenceSqlInsert extends AbstractSentenceSql {
private static final Logger LOGGER = LogManager.getLogger(SentenceSqlInsert.class);
private final String table;
private final String[] required;
private final String[] optional;
public SentenceSqlInsert(String name, String message, String table, List methods, List required,
List optional) {
super(name, message, methods);
this.table = table;
this.required = required.toArray(new String[required.size()]);
this.optional = optional.toArray(new String[optional.size()]);
}
@Override
public SentenceSqlType getType() {
return SentenceSqlType.INSERT;
}
@Override
public SentenceExecutionResult execute(DatabaseInterface databaseInterface, Connection connection,
Map context) throws SQLException {
int count = databaseInterface.executeInsert(connection, table, context, required, optional);
if (LOGGER.isInfoEnabled()) {
LOGGER.debug("inserted: {}", count);
}
if (count == 1) {
return SUCCESS;
} else {
return FAILURE;
}
}
@Override
public String outputName() {
return null;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy