Re: BUG #18829: RAISE NOTICE appends 's' to string in PostgreSQL 17.2 - Mailing list pgsql-bugs

From Andrew Dunstan
Subject Re: BUG #18829: RAISE NOTICE appends 's' to string in PostgreSQL 17.2
Date
Msg-id bdc1b820-f711-4749-8595-99aad004718a@dunslane.net
Whole thread Raw
In response to BUG #18829: RAISE NOTICE appends 's' to string in PostgreSQL 17.2  (PG Bug reporting form <noreply@postgresql.org>)
List pgsql-bugs


On 2025-03-02 Su 9:18 AM, PG Bug reporting form wrote:
The following bug has been logged on the website:

Bug reference:      18829
Logged by:          Armand
Email address:      armandnortjee@gmail.com
PostgreSQL version: 17.2
Operating system:   Windows 10
Description:        

In PostgreSQL 17.2, when using the RAISE NOTICE command with a string
variable, the output incorrectly appends an extra 's' to the string value.
This issue does not occur when running the same code in earlier PostgreSQL
versions (e.g., PostgreSQL 16).

DO $$
DECLARE    my_var TEXT := 'garth';
BEGIN    RAISE NOTICE '%s is slim', my_var;
END
$$;

Expected Result:
The output should be:
NOTICE:  garth is slim

Actual Result:
The output incorrectly shows:
NOTICE:  garths is slim


This is not a bug, it's working as documented.

The 's' is there because you told it to be there. The docs say: "Inside the format string, % is replaced by the string representation of the next optional argument's value."

This is not a printf style format string, as you appear to think it is.


cheers


andrew

--
Andrew Dunstan
EDB: https://www.enterprisedb.com

pgsql-bugs by date:

Previous
From: Tom Lane
Date:
Subject: Re: BUG #18829: RAISE NOTICE appends 's' to string in PostgreSQL 17.2
Next
From: Robert Treat
Date:
Subject: Re: BUG #18829: RAISE NOTICE appends 's' to string in PostgreSQL 17.2