RE: Fault with initcap - Mailing list pgsql-sql

From Jain, Ankit
Subject RE: Fault with initcap
Date
Msg-id 92eda9197fd74bf9aa9cd41bad115ec6@snapon.com
Whole thread Raw
In response to Re: Fault with initcap  (Metin Ulusinan <metin.ulusinan@ssicilian.net>)
List pgsql-sql

This was reported in PG 8.1.4 15 years ago - https://pgsql-bugs.postgresql.narkive.com/R7HmTKef/bug-2579-initcap-should-not-capitalize-letter-after-apostrophe

 

From: Metin Ulusinan <metin.ulusinan@ssicilian.net>
Sent: Wednesday, October 13, 2021 5:39 AM
To: Shaozhong SHI <shishaozhong@gmail.com>
Cc: pgsql-sql <pgsql-sql@lists.postgresql.org>
Subject: Re: Fault with initcap

 

CAUTION: This email originated from outside of Snap-on. Do not click on links or open attachments unless you have validated the sender, even if it is a known contact. Contact the sender by phone to validate the contents.

Hi,

Yes, this can be adaptable, and i did simple version of this. 

It just split text words with find spaces, capitalise each 

pieces(word) and merge together again.

This is a quick and simple work. You can develop over it about your needs.

 

Try that and tell us about result.

 

 

CREATE OR REPLACE FUNCTION initcap2(text)
 RETURNS text
 LANGUAGE plpgsql
AS $function$
DECLARE
sentence TEXT := '';
word_array TEXT[];
word TEXT;
word_out TEXT;
BEGIN
sentence := $1;

IF sentence is NULL THEN
RETURN NULL;
END IF;

word_array := regexp_split_to_array($1, E'\\s+');
FOREACH word IN ARRAY word_array
LOOP
word_out := upper(left(word, 1)) || lower(substring(word, 2));
sentence := regexp_replace(sentence, word, word_out);
END LOOP;

RETURN trim(sentence);
END;
$function$
;

 

 

 

On Wed, Oct 13, 2021 at 11:48 AM Shaozhong SHI <shishaozhong@gmail.com> wrote:

 

 

On Wed, 13 Oct 2021 at 07:33, Metin Ulusinan <metin.ulusinan@ssicilian.net> wrote:

I tried both on PostgreSQL 11.13 and yes "Sainsbury's bank" 's "S" is buggy, but notemachine is not.

 

Will anyone try @ 14?

 

 

n

s

version

Notemachine

Sainsbury'S Bank

PostgreSQL 11.13 (Debian 11.13-0+deb10u1) on x86_64-pc-linux-gnu, compiled by gcc (Debian 8.3.0-6) 8.3.0, 64-bit

 

 

Hello, Metin Ulusinan,

 

I can confirm that you pin-out the issue.

 

 

Can this be adapted to capitalise the first letter of each work in a string?

 

Regards,

 

David 

pgsql-sql by date:

Previous
From: Metin Ulusinan
Date:
Subject: Re: Fault with initcap
Next
From: Shaozhong SHI
Date:
Subject: Re: Fault with initcap