From 7f924ac4a4ebfb66ab242d59b21a4749432c40f1 Mon Sep 17 00:00:00 2001 From: wenyh1 <2365151147@qq.com> Date: Fri, 25 Aug 2023 17:29:52 +0800 Subject: [PATCH] [inner-2340] fix: explain' lost connection.... (cherry picked from commit 2b87829dc786e4644c4ee67bf842a94a887ec04f) --- .../dble/server/handler/ExplainHandler.java | 33 +++++++++++-------- 1 file changed, 20 insertions(+), 13 deletions(-) diff --git a/src/main/java/com/actiontech/dble/server/handler/ExplainHandler.java b/src/main/java/com/actiontech/dble/server/handler/ExplainHandler.java index 1e08e667c0..e964ba7ed7 100644 --- a/src/main/java/com/actiontech/dble/server/handler/ExplainHandler.java +++ b/src/main/java/com/actiontech/dble/server/handler/ExplainHandler.java @@ -45,6 +45,7 @@ import java.sql.SQLException; import java.sql.SQLNonTransientException; import java.sql.SQLSyntaxErrorException; +import java.util.LinkedList; import java.util.List; /** @@ -202,6 +203,7 @@ private static boolean isInsertSeq(ShardingService service, String stmt, SchemaC } public static void writeOutHeadAndEof(ShardingService service, RouteResultset rrs) { + final List rows = getRows(service, rrs); ByteBuffer buffer = service.allocate(); // writeDirectly header ResultSetHeaderPacket header = PacketUtil.getHeader(FIELD_COUNT); @@ -219,12 +221,23 @@ public static void writeOutHeadAndEof(ShardingService service, RouteResultset rr eof.setPacketId(service.nextPacketId()); buffer = eof.write(buffer, service, true); + // writeDirectly rows + for (RowDataPacket row : rows) { + row.setPacketId(service.nextPacketId()); + buffer = row.write(buffer, service, true); + } + + // writeDirectly last eof + EOFRowPacket lastEof = new EOFRowPacket(); + lastEof.setPacketId(service.nextPacketId()); + lastEof.write(buffer, service); + } + + private static List getRows(ShardingService service, RouteResultset rrs) { + LinkedList rows = new LinkedList<>(); if (!rrs.isNeedOptimizer()) { - // writeDirectly rows for (RouteResultsetNode node : rrs.getNodes()) { - RowDataPacket row = getRow(node, service.getCharset().getResults()); - row.setPacketId(service.nextPacketId()); - buffer = row.write(buffer, service, true); + rows.add(getRow(node, service.getCharset().getResults())); } } else { BaseHandlerBuilder builder = buildNodes(rrs, service); @@ -238,9 +251,7 @@ public static void writeOutHeadAndEof(ShardingService service, RouteResultset rr if (!StringUtil.isBlank(routeNode)) { RouteResultsetNode[] nodes = {new RouteResultsetNode(routeNode, rrs.getSqlType(), builder.getNode().getSql())}; for (RouteResultsetNode node : nodes) { - RowDataPacket row = getRow(node, service.getCharset().getResults()); - row.setPacketId(service.nextPacketId()); - buffer = row.write(buffer, service, true); + rows.add(getRow(node, service.getCharset().getResults())); } } else { List results = ComplexQueryPlanUtil.getComplexQueryResult(builder); @@ -249,14 +260,10 @@ public static void writeOutHeadAndEof(ShardingService service, RouteResultset rr row.add(StringUtil.encode(result.getName(), service.getCharset().getResults())); row.add(StringUtil.encode(result.getType(), service.getCharset().getResults())); row.add(StringUtil.encode(result.getRefOrSQL(), service.getCharset().getResults())); - row.setPacketId(service.nextPacketId()); - buffer = row.write(buffer, service, true); + rows.add(row); } } } - // writeDirectly last eof - EOFRowPacket lastEof = new EOFRowPacket(); - lastEof.setPacketId(service.nextPacketId()); - lastEof.write(buffer, service); + return rows; } }