(Gast)
n/a Beiträge
|
Re: Telefonnummern Trennen in Vorwahl-Rufnummer mit TSQL
22. Okt 2005, 19:41
Zitat von marabu:
Hallo Jens,
in T- SQL musst du die ONKZ-Tabelle mit einem less-than Vergleich an deiner normierten Nummer zerlegen, die Ordnung des Zwischenergebnisses umkehren und mit TOP 1 greifst du dann auf die korrekte Vorwahl zu.
Grüße vom marabu
Danke, das funktioniert gut.
Die Funktion läuft aber immer noch 0,4 bis 0,45 Sekunden.
Ich füge hier mal den Code ein, falls jemand mal Bedarf, oder Optimierungsvorschläge hat
SQL-Code:
CREATE FUNCTION SYSF_GetSplittedTelNumber (@TelNr VARCHAR(25) )
RETURNS VARCHAR(25)
AS
BEGIN
DECLARE @TestVorwahl VARCHAR(25)
DECLARE @TempResult VARCHAR(25)
IF @TelNr IS NULL OR LTRIM(@TelNr) =''
BEGIN
SET @TempResult = ''
END
ELSE BEGIN
SET @TelNr = REPLACE (@TelNr,'-','')
SET @TelNr = REPLACE (@TelNr,' ','')
SET @TelNr = REPLACE (@TelNr,'/','')
SET @TelNr = REPLACE (@TelNr,'(','')
SET @TelNr = REPLACE (@TelNr,')','')
SET @TelNr = REPLACE (@TelNr,'_','')
SET @TelNr = REPLACE (@TelNr,'+','')
SET @TelNr = REPLACE (@TelNr,'\','')
SET @TelNr = REPLACE (@TelNr,'"','')
SET @TelNr = REPLACE (@TelNr,'.','')
SET @TelNr = REPLACE (@TelNr,':','')
SET @TelNr = REPLACE (@TelNr,'*','')
SET @TelNr = REPLACE (@TelNr,'#','')
SET @TelNr = REPLACE (@TelNr,'p','')
SET @TelNr = REPLACE (@TelNr,'P','')
SET @TelNr = REPLACE (@TelNr,',','')
SET @TestVorwahl = @TelNr
SELECT TOP 1 @Testvorwahl=Vorwahl
FROM SYSF_Vorwahlen()
WHERE Vorwahl< @Testvorwahl
ORDER BY Vorwahl DESC
SET @TempResult= @TestVorwahl+'-'+RIGHT(@TelNr,LEN(@TelNr)-LEN(@TestVorwahl))
IF LEFT(@TempResult,1)='-' SET @TempResult=RIGHT(@TempResult,LEN(@TempResult)-1)
END
RETURN @TempResult
END
Schöne Grüße,
Jens
|