Обсуждение: psql --echo-queries does not echo all queries

Поиск
Список
Период
Сортировка

psql --echo-queries does not echo all queries

От
Gavin Wahl
Дата:
The -e/--echo-queries psql option is documented to "Copy all SQL
commands sent to the server to standard output as well." However, it
does not show queries sent to the server by -1/--single-transaction or
by ON_ERROR_ROLLBACK.

For example:

$ psql -e  -1 -c 'SELECT 1'
SELECT 1
 ?column?
----------
        1
(1 row)

While the server log reports:
2025-10-24 12:01:57.937 MDT [1970796] LOG:  duration: 0.035 ms  statement: BEGIN
2025-10-24 12:01:57.937 MDT [1970796] LOG:  duration: 0.085 ms
statement: SELECT 1
2025-10-24 12:01:57.937 MDT [1970796] LOG:  duration: 0.004 ms
statement: COMMIT

The BEGIN/END are not reported by psql.


$ psql -e -v ON_ERROR_ROLLBACK=on
psql (16.9)
Type "help" for help.

# BEGIN;
BEGIN;
BEGIN
# SELECT 1;
SELECT 1;
 ?column?
----------
        1
(1 row)

While the server log reports:
2025-10-24 12:12:21.517 MDT [1974726] LOG:  duration: 0.077 ms
statement: BEGIN;
2025-10-24 12:12:25.757 MDT [1974726] LOG:  duration: 0.048 ms
statement: SAVEPOINT pg_psql_temporary_savepoint
2025-10-24 12:12:25.757 MDT [1974726] LOG:  duration: 0.156 ms
statement: SELECT 1;
2025-10-24 12:12:25.757 MDT [1974726] LOG:  duration: 0.012 ms
statement: RELEASE pg_psql_temporary_savepoint

The savepoints are not reported by psql.



Re: psql --echo-queries does not echo all queries

От
Tom Lane
Дата:
Gavin Wahl <gavinwahl@gmail.com> writes:
> The -e/--echo-queries psql option is documented to "Copy all SQL
> commands sent to the server to standard output as well." However, it
> does not show queries sent to the server by -1/--single-transaction or
> by ON_ERROR_ROLLBACK.

Did you try

  -E, --echo-hidden        display queries that internal commands generate

?

            regards, tom lane



Re: psql --echo-queries does not echo all queries

От
Gavin Wahl
Дата:
I tried with -E and it does echo the BEGIN/END used to implement
-1/--single-transaction, but not the SAVEPOINT queries for
ON_ERROR_ROLLBACK.  It looks like SendQuery is calling PQexec directly
instead of calling the PSQLexec wrapper function that does the
logging. I happened to notice that the queries emitted by \watch, nor
the BEGIN for autocommit, aren't logged by either option as well.

I think this may be a documentation bug as well? I would expect -e to
be a superset of -E:

 -E
 --echo-hidden
     Echo the actual queries generated by \d and other backslash commands.

 -e
 --echo-queries
     Copy *ALL* [emphasis mine] SQL commands sent to the server to
standard output as well