PostgreSQL
 sql >> Datenbank >  >> RDS >> PostgreSQL

Ersetzen von mit Regex übereinstimmendem Text durch die Großbuchstabenversion in Postgresql

Sie können eine PL/pgSQL-Funktion wie folgt erstellen:

CREATE FUNCTION upper_asterisk(inp_str varchar)
RETURNS varchar AS $$
DECLARE t_str varchar;
BEGIN

  FOR t_str IN (SELECT regexp_matches(inp_str,'\*.+\*','g'))
  BEGIN
    inp_str := replace(inp_str, t_str, upper(t_str));
  END;

  RETURN inp_str;
END;
$$  LANGUAGE plpgsql;

(Nicht getestet, kann Fehler enthalten).

Oder verwenden Sie eine beliebige verfügbare Sprache, um eine solche Funktion in DB zu schreiben.