Datenbank Felder formatieren
Hallo !!!
Vielleicht hat jemand von euch eine Idee. Habe eine Tabelle wo wir Tel. Nr gespeichert haben.
Leider haben sich nicht alle an das Format gehalten. Dies soll anderes werden. Möchte auch nicht alle Einträge per Hand ändern und bisher auch nichts sinniges gefunden.
Folgendes Scenario.
Die tel. Nr. sollen so gespeichert werden (089) 123-4567,
sind aber teilweise 089 123-4567.
Wie bekomme ich ein Format hin das mir alle Einträge auf einmal wie gewünscht anpasst ??
Habt ihr eine Idee ?
MfG
Vielleicht hat jemand von euch eine Idee. Habe eine Tabelle wo wir Tel. Nr gespeichert haben.
Leider haben sich nicht alle an das Format gehalten. Dies soll anderes werden. Möchte auch nicht alle Einträge per Hand ändern und bisher auch nichts sinniges gefunden.
Folgendes Scenario.
Die tel. Nr. sollen so gespeichert werden (089) 123-4567,
sind aber teilweise 089 123-4567.
Wie bekomme ich ein Format hin das mir alle Einträge auf einmal wie gewünscht anpasst ??
Habt ihr eine Idee ?
MfG
Bitte markiere auch die Kommentare, die zur Lösung des Beitrags beigetragen haben
Content-ID: 44734
Url: https://administrator.de/contentid/44734
Ausgedruckt am: 23.11.2024 um 12:11 Uhr
2 Kommentare
Neuester Kommentar
Moin GoCrash,
ich habe auch schon im Parallelthread "Daten in Spalten formatieren " (in Excel) mitgelesen.
Und finde es grundsätzlich die falsche Herangehensweise, wie ihr mit der Tel-Nummer umgeht.
Das eine ist die Formatierung. Wie es angezeigt, wie es ausgedruckt werden soll.
Das andere ist die Persistierung, das Speichern in der Datenbank.
Datenbank kommt von "Daten", sonst würde es es "Formatierungsbank" heißen.
Diese Klammern und Leerzeichen und (bei vielen Telefonnummern-Darstellungen) Pluszeichen sind nicht informationshaltig.
Ebensowenig wie die Bindestriche bei ISBN- oder Sozialversicherungsnummer.
Oder ein Euro-Zeichen oder Tausenderpunkte bei Beträgen.
LASS ES DRAUSSEN.
Da ich aber die Erfahrung gemacht habe, dass viele meiner Empfehlungen hier im Forum ungehört verhallen,
... noch eine Demo von dem, was ich meine.
Wenn Du auf eine Tabelle zugreifst mit einem Telefonnummernfeld und bei dieser Abfrage
...dann kannst Du in der Anzeige ganz anders damit umgehen.
[M$-Access-Syntax; nicht Standard-SQL]
Also was soll's?
Natürlich kannst Du einmalig eine UPDATE-Abfrage über Deine Tabelle schrapeln lassen:
Aber das bringt nur etwas, wenn Du dann bei der Eingabe durch ein entsprechendes Eingabeformat in Eurer GUI sicherstellst, dass in Zukunft immer so ein schön formatierter Text eingegeben wird.
Grüße
Biber
P.S. M$ speichert tranigerweise z.B. bei Outlook auch solche TelNR-Formatierungen mit.
Probier mal, so einen Dreck in ein anderes Adressbuch zu bekommen ohne PERL...
ich habe auch schon im Parallelthread "Daten in Spalten formatieren " (in Excel) mitgelesen.
Und finde es grundsätzlich die falsche Herangehensweise, wie ihr mit der Tel-Nummer umgeht.
Das eine ist die Formatierung. Wie es angezeigt, wie es ausgedruckt werden soll.
Das andere ist die Persistierung, das Speichern in der Datenbank.
Datenbank kommt von "Daten", sonst würde es es "Formatierungsbank" heißen.
Diese Klammern und Leerzeichen und (bei vielen Telefonnummern-Darstellungen) Pluszeichen sind nicht informationshaltig.
Ebensowenig wie die Bindestriche bei ISBN- oder Sozialversicherungsnummer.
Oder ein Euro-Zeichen oder Tausenderpunkte bei Beträgen.
LASS ES DRAUSSEN.
Da ich aber die Erfahrung gemacht habe, dass viele meiner Empfehlungen hier im Forum ungehört verhallen,
... noch eine Demo von dem, was ich meine.
Wenn Du auf eine Tabelle zugreifst mit einem Telefonnummernfeld und bei dieser Abfrage
select AlteTel from TelefonAbfrage;
....dieses Ergebnis bekommst....
AlteTel
030 7411-551
(030) 4711-11
07198 728342
51111
....
[M$-Access-Syntax; nicht Standard-SQL]
SELECT AlteTel,
IIf(Instr(AlteTel," ")=0,"",
"(" & Replace(Replace( Mid( AlteTel,1,Instr(AlteTel," ")-1 ), "(","") ,")","") & ")") as Vorwahl,
Mid(AlteTel,Instr(AlteTel," ")+1) as TelNr
,IIf(Instr(AlteTel," ")=0,"",
"(" & Replace(Replace( Mid( AlteTel,1,Instr(AlteTel," ")-1 ), "(","") ,")","") & ") ") & Mid(AlteTel,Instr(AlteTel," ")+1) as NeueTel
FROM Telefonabfrage;
AlteTel | Vorwahl | TelNr | NeueTel |
030 7411-551 | (030) | 7411-551 | (030) 7411-551 |
(030) 4711-11 | (030) | 4711-11 | (030) 4711-11 |
07198 728342 | (07198) | 728342 | (07198) 728342 |
51111 | 51111 | 51111 |
Also was soll's?
Natürlich kannst Du einmalig eine UPDATE-Abfrage über Deine Tabelle schrapeln lassen:
UPDATE TelefonAbfrage
SET AlteTel =
IIf(Instr(AlteTel," ")=0,"",
"(" & Replace(Replace( Mid( AlteTel,1,Instr(AlteTel," ")-1 ), "(","") ,")","") & ") ") & Mid(AlteTel,Instr(AlteTel," ")+1) ;
Aber das bringt nur etwas, wenn Du dann bei der Eingabe durch ein entsprechendes Eingabeformat in Eurer GUI sicherstellst, dass in Zukunft immer so ein schön formatierter Text eingegeben wird.
Grüße
Biber
P.S. M$ speichert tranigerweise z.B. bei Outlook auch solche TelNR-Formatierungen mit.
Probier mal, so einen Dreck in ein anderes Adressbuch zu bekommen ohne PERL...