![]() |
Datenbank: MS SQL Server • Version: 2008 • Zugriff über: MS SQL Server Management Studio
Vor- und Nachnamen splitten
Hallo DPler,
ich muss aus einer Tabelle Daten nehmen und diese geparst in eine andere Tabelle uebernehmen. In meiner Ausgangstabelle sind Vor- und Nachnamen zusammen in einer Spalte getrennt durch ein Leerzeichen. Diesen Namen muss ich jetzt splitten und in der Zieltabelle unter Firstname und Lastname eintragen. Leider ist mein SQL zu sehr eingerostet und ich bekomme es leider nicht hin diesen Vor/Nachnamen zu splitten. Ich versuchte es mit Substring, LTRIM, RTRIM, aber es wird einfach nichts. Koennte jemand von euch mir bitte helfen? Danke. Das ist der aktuelle SQL Code den ich habe und wo ich steckengeblieben bin:
Code:
NSERT INTO Leads (BTN,
JCN, ACCT_NUMBER, FIRSTNAME, LASTNAME, ADDRESS, ADDRESS2, CITY, STATE, ZIP, Import_Date) SELECT Daily_Temp.dbo.No_Schedule_042512.[HOME PHONE], '5113', Daily_Temp.dbo.No_Schedule_042512.[ACCOUNT NUMBER], SUBSTRING(Daily_Temp.dbo.No_Schedule_042512.[CUSTOMER NAME], 1, CHARINDEX(' ', |
AW: Vor- und Nachnamen splitten
Du hast es doch schon
Code:
Select RTRIM(SUBSTRING(name,1,CHARINDEX(' ',Name))) as Vorname,
LTRIM(SUBSTRING(name,CHARINDEX(' ',Name),Len(Name))) as Name from Names |
AW: Vor- und Nachnamen splitten
Nur dass ein Splitten am ersten Leerzeichen natürlich recht unzuverlässig ist. Was machst Du aus "Hans Hugo Müller", was aus "Maria Antonia vom Schloss", die nach der Hochzeit auch noch zu "Maria Antonia Müller-vom Schloss" wird?
|
AW: Vor- und Nachnamen splitten
Richtig, die ursprüngliche (nicht ordentlich normalisierte) Datenstruktur rächt sich nun, so dass es ohne manuelles Nacharbeiten ohnehin nicht geht. Man kann lediglich versuchen, den Regelfall abzubilden, aber der Datenbestand muss anschließend kontrolliert werden.
|
AW: Vor- und Nachnamen splitten
Zitat:
Oder man loggt die entsprechenden Namen irgenwo mit. Das würde zumindestens die Suche nach offensichtlichen Problemen beschleunigen. |
AW: Vor- und Nachnamen splitten
Zitat:
Beim ersten Leerzeichen (von vorne) zu splitten ist kompletter Unsinn, beim ersten Leerzeichen (von hinten) zu splitten erfordert anschließend etwas/minimal weniger Handarbeit bei der Datenkontrolle :evil: Und dann gibt es noch die Österreicher, die nicht "Otto Normalverbraucher" heißen, sondern "Normalverbraucher Otto". Vor- und Nachname also andersrum :evil: Wie DeddyH schon schrub: Es RÄCHT sich! GG |
AW: Vor- und Nachnamen splitten
Zitat:
Ja es rächt sich, aber das Kind ist ja schon in den Brunnen gefallen, wahrscheinlich nicht mal in Ihren eigenen ... |
AW: Vor- und Nachnamen splitten
Es scheint eher das Nachbarkind in seinen Brunnen gefallen zu sein.
Die Zeit, die man sich beim Design spart, wendet man nunmal x-fach später auf, um das unsaubere Design zu fixen. |
AW: Vor- und Nachnamen splitten
Zitat:
Schrieb, schrub? Schrob :thumb: Beim Datenbankdesign liebe ich Frau "Sabine Leutheusser-Schnarrenberger" wegen der Feldlängen. Und wünsche Ihrem Ehegatten einen "Prof. h. c." schon wegen der Leerzeichen im Titel :wink: GG |
AW: Vor- und Nachnamen splitten
Das Problem ist eben dass wir diese Dateien so von unseren Kunden bekommen und eingelesen werden müssen. Ganz schlimm sind diese hier: Hans * Meier. Kein Mensch weiß warum manche Namen ein * darin haben. Oder Namen wie diesen hier: LAURA * VERARDO GOODRIC
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 10:06 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz