PDA

View Full Version : Telefonnummern Zeichen ersetzen



mk
07-03-23, 12:17
Hallo *ALL,

ich baue einen View mit Telefonnummern.


Also z.B.

Ländervorwahl +49
Ortsvorwahl 02055
Anschluss 444
Durchwahl 123

Diese werden zu einem Feld zusammengefügt.
trim(a.kdtelvw) concat trim( a.KDTEOVW ) concat trim( a.KDPTTE) concat trim( a.KDTEDWL ) as Telefonnummer ,


In den einzelnen Feldern können aber auch - oder / oder sonstige zeichen stehen

Gibt es im SQL eine Möglichkeit alles zu trimmen und ersetzten was nicht numerisch ist ?

Gruß
Michael

prsbrc
07-03-23, 12:40
Hallo.
Nichts mir bekanntes.
Ganz naiv würde ich dir aber eine UDF vorschlagen zu basteln welches die Zeichen mittels REPLACE bereits entfernt.

Ahoy
07-03-23, 13:02
Hallo,

hier eine SQL UDF um alles nicht-numerische aus Strings zu entfernen:


CREATE OR REPLACE FUNCTION STRPNONNUM(VAL VARCHAR(50))
RETURNS VARCHAR(50)
LANGUAGE SQL
DETERMINISTIC
CONTAINS SQL
RETURNS NULL ON NULL INPUT
ALLOW PARALLEL
NO EXTERNAL ACTION
BEGIN
RETURN REPLACE(TRANSLATE(VAL,' ',x'000102030405060708090A0B0C0D0E0F10111213141516 1718191A1B1C1D1E1F202122232425262728292A2B2C2D2E2F 303132333435363738393A3B3C3D3E3F404142434445464748 494A4B4C4D4E4F505152535455565758595A5B5C5D5E5F6061 62636465666768696A6B6C6D6E6F707172737475767778797A 7B7C7D7E7F808182838485868788898A8B8C8D8E8F90919293 9495969798999A9B9C9D9E9FA0A1A2A3A4A5A6A7A8A9AAABAC ADAEAFB0B1B2B3B4B5B6B7B8B9BABBBCBDBEBFC0C1C2C3C4C5 C6C7C8C9CACBCCCDCECFD0D1D2D3D4D5D6D7D8D9DADBDCDDDE DFE0E1E2E3E4E5E6E7E8E9EAEBECEDEEEFFAFBFCFDFEFF'), ' ');
END;

B.Hauser
07-03-23, 16:17
REGEXP_REPLACE kann das!


Select RegexP_Replace(TelefonNr, '[\D]', ''), TelefonNr, x.*
from YourTable x

Ahoy
08-03-23, 06:16
Wenn die View viel genutzt wird, ist es vielleicht sinnvoll zu testen welche Variante die bessere Performance hat. Wobei die REGEX Variante natürlich die elegantere Variante ist.

Fuerchau
08-03-23, 08:45
Diese Variante kann man auch in einen Computed Index aufnehmen, dann ist das Suchen per View mit diesem Ausdruck über einen Index gewährleistet.

mk
13-03-23, 10:32
Hi zusammen,
sorry für die späte Rückmeldung.
Unser Azubi hat die Variante mit der Regex als SQL Funktion erstellt

RETURN REGEXP_REPLACE(givenString, '[^[:digit:]]');

Fuerchau
13-03-23, 15:23
Ist das selbe:
\D => [^[:digit:]]

Es sei denn, die IBM unterstützt \D nicht.
Regex ist case sensitive:
\d = Ziffern
\D <> Ziffern