I think libmariadb has a nicer interface for this. Essentially what you do is send your query, and then read a result set (one result set per query), and then you stream individual rows using: mysql_fetch_row_start mysql_fetch_row_cont Those methods don't seem to have an equivalent in libpq - you can use PQgetResult but it buffers all the rows. Using single row mode results in many results for each query (seems like a big overhead). The difference between this and MariaDB is that mysql_fetch_row still operates within one logical set of results, but single row mode breaks the single logical set of results into lots of individual results. Maybe the statement about efficiency is incorrect, but it would be nice if you could incrementally stream a single result set more easily. On Sun, 28 Jun 2020 at 02:40, Tom Lane <tgl@xxxxxxxxxxxxx> wrote: > > Samuel Williams <space.ship.traveller@xxxxxxxxx> writes: > > Here is a short example: > > https://gist.github.com/ioquatix/2f08f78699418f65971035785c80cf18 > > It makes 10 queries in one "PQsendQuery" and sets single row mode. But > > all the results come back at once as shown by the timestamps. > > That looks to be less about what libpq will do than what the Ruby > interface code will do. > > The volume of return data may also be an issue. I don't think the > backend will flush data out to the client except when it (a) reaches > an idle state or (b) fills the output buffer. Ten occurrences of > a short query result aren't gonna be enough for (b) --- from memory, > that buffer is probably 8KB. > > regards, tom lane