|  | MySQL 8.0.43
    Source Code Documentation | 
A Text Resultset is a possible COM_QUERY Response.
It is made up of 2 parts:
The column definitions part starts with a packet containing the column-count, followed by as many Column Definition packets as there are columns and terminated by a EOF_Packet if the CLIENT_DEPRECATE_EOF is not set.
Each row is a packet, too. The rows are terminated by another EOF_Packet. In case the query could generate the Column Definition set, but generating the rows afterwards failed, a ERR_Packet may be sent instead of the last EOF_Packet.
| Type | Name | Description | 
|---|---|---|
| if capabilities & CLIENT_OPTIONAL_RESULTSET_METADATA { | ||
| int<1> | metadata_follows | Flag specifying if metadata are skipped or not. See enum_resultset_metadata | 
| } | ||
| int<lenenc> | column_count | Number of Column Definition to follow | 
| if (not (capabilities & CLIENT_OPTIONAL_RESULTSET_METADATA)) or metadata_follows== RESULTSET_METADATA_FULL { | ||
| column_countx Column Definition | Field metadata | one Column Definition for each field up to column_count | 
| } | ||
| if (not capabilities & CLIENT_DEPRECATE_EOF) { | ||
| EOF_Packet | End of metadata | Marker to set the end of metadata | 
| } | ||
| One or more Text Resultset Row | The row data | each Text Resultset Row contains column_countvalues | 
| if (error processing) { | ||
| ERR_Packet | terminator | Error details | 
| } else if capabilities & CLIENT_DEPRECATE_EOF { | ||
| OK_Packet | terminator | All the execution details | 
| } else { | ||
| EOF_Packet | terminator | end of resultset marker | 
| } | ||
If the SERVER_MORE_RESULTS_EXISTS flag is set in the last EOF_Packet / OK_Packet, another Text Resultset will follow. See Multi-resultset.