package io.vertx.pgclient.impl.codec;
import io.vertx.sqlclient.impl.PreparedStatement;
import io.vertx.sqlclient.impl.ParamDesc;
import io.vertx.sqlclient.impl.TupleInternal;
class PgPreparedStatement implements PreparedStatement {
final String sql;
final Bind bind;
final PgParamDesc paramDesc;
final PgRowDesc rowDesc;
final boolean cached;
PgPreparedStatement(String sql, long statement, PgParamDesc paramDesc, PgRowDesc rowDesc, boolean cached) {
this.paramDesc = paramDesc;
this.rowDesc = rowDesc;
this.sql = sql;
this.bind = new Bind(statement, paramDesc != null ? paramDesc.paramDataTypes() : null, rowDesc != null ? rowDesc.columns : PgColumnDesc.EMPTY_COLUMNS);
this.cached = cached;
}
@Override
public ParamDesc paramDesc() {
return paramDesc;
}
@Override
public PgRowDesc rowDesc() {
return rowDesc;
}
@Override
public String sql() {
return sql;
}
@Override
public String prepare(TupleInternal values) {
return paramDesc.prepare(values);
}
public boolean isCached() {
return cached;
}
@Override
public String toString() {
return "PreparedStatement[" + sql + "]";
}
}