use of com.mysql.cj.protocol.x.StatementExecuteOkBuilder in project aws-mysql-jdbc by awslabs.
the class MysqlxSession method query.
public <M extends Message, R, RES> RES query(M message, Predicate<Row> rowFilter, Function<Row, R> rowMapper, Collector<R, ?, RES> collector) {
this.protocol.send(message, 0);
ColumnDefinition metadata = this.protocol.readMetadata();
Iterator<Row> ris = new XProtocolRowInputStream(metadata, (XProtocol) this.protocol, null);
Stream<Row> stream = StreamSupport.stream(Spliterators.spliteratorUnknownSize(ris, 0), false);
if (rowFilter != null) {
stream = stream.filter(rowFilter);
}
RES result = stream.map(rowMapper).collect(collector);
this.protocol.readQueryResult(new StatementExecuteOkBuilder());
return result;
}
use of com.mysql.cj.protocol.x.StatementExecuteOkBuilder in project aws-mysql-jdbc by awslabs.
the class SqlResultBuilder method addProtocolEntity.
@Override
public boolean addProtocolEntity(ProtocolEntity entity) {
if (entity instanceof Field) {
this.fields.add((Field) entity);
if (!this.isRowResult) {
this.isRowResult = true;
}
this.prevEntity = entity;
return false;
} else if (entity instanceof Notice) {
this.statementExecuteOkBuilder.addProtocolEntity(entity);
return false;
}
if (this.isRowResult && this.metadata == null) {
this.metadata = new DefaultColumnDefinition(this.fields.toArray(new Field[] {}));
}
if (entity instanceof Row) {
this.rows.add(((Row) entity).setMetadata(this.metadata));
} else if (entity instanceof FetchDoneMoreResults) {
this.resultSets.add(new SqlSingleResult(this.metadata, this.defaultTimeZone, new BufferedRowList(this.rows), () -> this.statementExecuteOkBuilder.build(), this.pset));
// clear variables to accept next result set
this.fields = new ArrayList<>();
this.metadata = null;
this.rows = new ArrayList<>();
this.statementExecuteOkBuilder = new StatementExecuteOkBuilder();
} else if (entity instanceof FetchDoneEntity) {
if (this.prevEntity instanceof FetchDoneMoreResults) {
// no-op, possibly bug in xplugin sending FetchDone immediately following FetchDoneMoreResultsets
} else {
this.resultSets.add(new SqlSingleResult(this.metadata, this.defaultTimeZone, new BufferedRowList(this.rows), () -> this.statementExecuteOkBuilder.build(), this.pset));
}
} else if (entity instanceof StatementExecuteOk) {
return true;
}
this.prevEntity = entity;
return false;
}
use of com.mysql.cj.protocol.x.StatementExecuteOkBuilder in project aws-mysql-jdbc by awslabs.
the class StreamingSqlResultBuilder method addProtocolEntity.
@Override
public boolean addProtocolEntity(ProtocolEntity entity) {
if (entity instanceof Notice) {
this.statementExecuteOkBuilder.addProtocolEntity(entity);
} else {
this.lastEntity = entity;
}
AtomicBoolean readLastResult = new AtomicBoolean(false);
Supplier<ProtocolEntity> okReader = () -> {
if (readLastResult.get()) {
throw new CJCommunicationsException("Invalid state attempting to read ok packet");
}
if (this.protocol.hasMoreResults()) {
StatementExecuteOk res = this.statementExecuteOkBuilder.build();
this.statementExecuteOkBuilder = new StatementExecuteOkBuilder();
return res;
}
readLastResult.set(true);
return this.protocol.readQueryResult(this.statementExecuteOkBuilder);
};
Supplier<SqlResult> resultStream = () -> {
if (readLastResult.get()) {
return null;
} else if (this.lastEntity != null && this.lastEntity instanceof Field || this.protocol.isSqlResultPending()) {
ColumnDefinition cd;
if (this.lastEntity != null && this.lastEntity instanceof Field) {
cd = this.protocol.readMetadata((Field) this.lastEntity, (n) -> {
this.statementExecuteOkBuilder.addProtocolEntity(n);
});
this.lastEntity = null;
} else {
cd = this.protocol.readMetadata(this.statementExecuteOkBuilder::addProtocolEntity);
}
return new SqlSingleResult(cd, this.protocol.getServerSession().getDefaultTimeZone(), new XProtocolRowInputStream(cd, this.protocol, (n) -> {
this.statementExecuteOkBuilder.addProtocolEntity(n);
}), okReader, this.pset);
} else {
readLastResult.set(true);
SqlResultBuilder rb = new SqlResultBuilder(this.defaultTimeZone, this.pset);
rb.addProtocolEntity(entity);
return this.protocol.readQueryResult(rb);
}
};
this.result = new SqlMultiResult(resultStream);
return true;
}
Aggregations