Re: query logging of prepared statements
От | Justin Pryzby |
---|---|
Тема | Re: query logging of prepared statements |
Дата | |
Msg-id | 20190227180653.GF28750@telsasoft.com обсуждение исходный текст |
Ответ на | Re: query logging of prepared statements (Justin Pryzby <pryzby@telsasoft.com>) |
Ответы |
Re: query logging of prepared statements
|
Список | pgsql-hackers |
On Fri, Feb 15, 2019 at 08:57:04AM -0600, Justin Pryzby wrote: > I propose that the prepared statement associated with an EXECUTE should be > included in log "DETAIL" only when log_error_verbosity=VERBOSE, for both SQL > EXECUTE and PQexecPrepared (if at all). I'd like to be able to continue > logging DETAIL (including bind parameters), so want like to avoid setting > "TERSE" just to avoid redundant messages. (It occurs to me that the GUC should > probably stick to its existing documented behavior rather than be extended, > which suggests that the duplicitive portions of the logs should simply be > removed, rather than conditionalized. Let me know what you think). I'm attaching a v2 patch which avoids repeated logging of PREPARE, rather than making such logs conditional on log_error_verbosity=VERBOSE, since log_error_verbosity is documented to control whether these are output: DETAIL/HINT/QUERY/CONTEXT/SQLSTATE. For SQL EXECUTE, excluding "detail" seems reasonable (perhaps for log_error_verbosity<VERBOSE). But for PQexecPrepared, the v1 patch made log_error_verbosity also control the "message" output, which is outside the scope of its documented behavior. |message | execute qq: PREPARE qq AS SELECT $1 |detail | parameters: $1 = '3' https://www.postgresql.org/docs/current/runtime-config-logging.html |Controls the amount of detail written in the server log for each message that |is logged. Valid values are TERSE, DEFAULT, and VERBOSE, each adding more |fields to displayed messages. TERSE excludes the logging of DETAIL, HINT, |QUERY, and CONTEXT error information. VERBOSE output includes the SQLSTATE |error code (see also Appendix A) and the source code file name, function name, |and line number that generated the error. Only superusers can change this |setting. As I mentioned in my original message, it seems odd that for SQL EXECUTE, the PREPARE is shown in "detail", but for the library call, it's shown in "message". This patch resolves that inconsistency by showing it in neither.
Вложения
В списке pgsql-hackers по дате отправления: