Delphi-PRAXiS
Seite 1 von 3  1 23      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Vor- und Nachnamen splitten (https://www.delphipraxis.net/167947-vor-und-nachnamen-splitten.html)

Mackhack 26. Apr 2012 20:58

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(' ',

Bummi 26. Apr 2012 22:58

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

CCRDude 27. Apr 2012 08:45

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?

DeddyH 27. Apr 2012 08:50

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.

himitsu 27. Apr 2012 09:07

AW: Vor- und Nachnamen splitten
 
Zitat:

Zitat von DeddyH (Beitrag 1163794)
Man kann lediglich versuchen, den Regelfall abzubilden, aber der Datenbestand muss anschließend kontrolliert werden.

Man könnte noch ein Bool-Feld einfügen, worin die Aufteilfunktion erwähnt, ob sie Aufälligkeiten entdeckt hat, wie z.B. mehr als ein Leerzeichen vorhanden, bzw. mehr als 2 Wörter erkannt.
Oder man loggt die entsprechenden Namen irgenwo mit.

Das würde zumindestens die Suche nach offensichtlichen Problemen beschleunigen.

Gustav.R 27. Apr 2012 11:19

AW: Vor- und Nachnamen splitten
 
Zitat:

Zitat von DeddyH (Beitrag 1163794)
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.

Wie wahr, wie wahr :evil:

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

Bummi 27. Apr 2012 11:23

AW: Vor- und Nachnamen splitten
 
Zitat:

schrub
? >> Schriebte !

Ja es rächt sich, aber das Kind ist ja schon in den Brunnen gefallen, wahrscheinlich nicht mal in Ihren eigenen ...

mkinzler 27. Apr 2012 11:25

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.

Gustav.R 27. Apr 2012 11:43

AW: Vor- und Nachnamen splitten
 
Zitat:

Zitat von mkinzler (Beitrag 1163825)
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.

Bei mir war es tatsächlich das Nachbarkind. Habe den Spalteninhalt der kombinierten VorNachnamenspalte dann nach Excel rüberkopiert und mit Excel rumgebastelt (war einfach einfacher als mit Delphi rumzufummeln).

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

Mackhack 27. Apr 2012 17:57

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 16:11 Uhr.
Seite 1 von 3  1 23      

Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz