org.embulk.input.tsurugidb.getter.IntColumnGetter Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of embulk-input-tsurugidb Show documentation
Show all versions of embulk-input-tsurugidb Show documentation
Selects records from a table.
The newest version!
package org.embulk.input.tsurugidb.getter;
import java.io.IOException;
import java.util.List;
import org.embulk.spi.Column;
import org.embulk.spi.PageBuilder;
import org.embulk.spi.type.Type;
import org.embulk.spi.type.Types;
import com.fasterxml.jackson.databind.JsonNode;
import com.tsurugidb.sql.proto.SqlRequest.Parameter;
import com.tsurugidb.tsubakuro.exception.ServerException;
import com.tsurugidb.tsubakuro.kvs.Record;
import com.tsurugidb.tsubakuro.kvs.RecordBuffer;
import com.tsurugidb.tsubakuro.sql.Parameters;
import com.tsurugidb.tsubakuro.sql.ResultSet;
// https://github.com/embulk/embulk-input-jdbc/blob/master/embulk-input-jdbc/src/main/java/org/embulk/input/jdbc/getter/LongColumnGetter.java
public class IntColumnGetter extends AbstractColumnGetter {
protected int value;
public IntColumnGetter(PageBuilder to, Type toType) {
super(to, toType);
}
@Override
protected void fetch(ResultSet from) throws IOException, ServerException, InterruptedException {
value = from.fetchInt4Value();
}
@Override
protected void fetch(Record from, String name) {
value = from.getInt(name);
}
@Override
protected Type getDefaultToType() {
return Types.LONG;
}
@Override
public void booleanColumn(Column column) {
to.setBoolean(column, value > 0);
}
@Override
public void longColumn(Column column) {
to.setLong(column, value);
}
@Override
public void doubleColumn(Column column) {
to.setDouble(column, value);
}
@Override
public void stringColumn(Column column) {
to.setString(column, Long.toString(value));
}
@Override
public JsonNode encodeToJson() {
return jsonNodeFactory.numberNode(value);
}
@Override
public void decodeFromJsonTo(List toStatement, String toIndex, JsonNode fromValue) {
int v = fromValue.asInt();
var parameter = Parameters.of(toIndex, v);
toStatement.add(parameter);
}
@Override
public void decodeFromJsonTo(RecordBuffer toRecord, String toIndex, JsonNode fromValue) {
int v = fromValue.asInt();
toRecord.add(toIndex, v);
}
}