AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Vor- und Nachnamen splitten

Vor- und Nachnamen splitten

Ein Thema von Mackhack · begonnen am 26. Apr 2012 · letzter Beitrag vom 29. Apr 2012
Antwort Antwort
Seite 1 von 3  1 23   
Benutzerbild von Mackhack
Mackhack

Registriert seit: 29. Nov 2003
Ort: San Diego, CA/USA
1.446 Beiträge
 
Delphi 2006 Architect
 
#1

Vor- und Nachnamen splitten

  Alt 26. Apr 2012, 21:58
Datenbank: MS SQL Server • Version: 2008 • Zugriff über: MS SQL Server Management Studio
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(' ',
Um etwas Neues zu schaffen muss man seine Ohren vor den Nein-sagern verschliessen um seinen Geist öffnen zu können.
(George Lukas)
  Mit Zitat antworten Zitat
Benutzerbild von Bummi
Bummi

Registriert seit: 15. Jun 2010
Ort: Augsburg Bayern Süddeutschland
3.470 Beiträge
 
Delphi XE3 Enterprise
 
#2

AW: Vor- und Nachnamen splitten

  Alt 26. Apr 2012, 23:58
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
Thomas Wassermann H₂♂
Das Problem steckt meistens zwischen den Ohren
DRY DRY KISS
H₂ (wenn bei meinen Snipplets nichts anderes angegeben ist Lizenz: WTFPL)
  Mit Zitat antworten Zitat
CCRDude

Registriert seit: 9. Jun 2011
675 Beiträge
 
FreePascal / Lazarus
 
#3

AW: Vor- und Nachnamen splitten

  Alt 27. Apr 2012, 09:45
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?
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.534 Beiträge
 
Delphi 11 Alexandria
 
#4

AW: Vor- und Nachnamen splitten

  Alt 27. Apr 2012, 09:50
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.
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
43.017 Beiträge
 
Delphi 12 Athens
 
#5

AW: Vor- und Nachnamen splitten

  Alt 27. Apr 2012, 10:07
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.
Garbage Collector ... Delphianer erzeugen keinen Müll, also brauchen sie auch keinen Müllsucher.
my Delphi wish list : BugReports/FeatureRequests
  Mit Zitat antworten Zitat
Gustav.R
(Gast)

n/a Beiträge
 
#6

AW: Vor- und Nachnamen splitten

  Alt 27. Apr 2012, 12:19
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

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

Und dann gibt es noch die Österreicher, die nicht "Otto Normalverbraucher" heißen, sondern "Normalverbraucher Otto". Vor- und Nachname also andersrum

Wie DeddyH schon schrub: Es RÄCHT sich!

GG
  Mit Zitat antworten Zitat
Benutzerbild von Bummi
Bummi

Registriert seit: 15. Jun 2010
Ort: Augsburg Bayern Süddeutschland
3.470 Beiträge
 
Delphi XE3 Enterprise
 
#7

AW: Vor- und Nachnamen splitten

  Alt 27. Apr 2012, 12:23
Zitat:
schrub
? >> Schriebte !

Ja es rächt sich, aber das Kind ist ja schon in den Brunnen gefallen, wahrscheinlich nicht mal in Ihren eigenen ...
Thomas Wassermann H₂♂
Das Problem steckt meistens zwischen den Ohren
DRY DRY KISS
H₂ (wenn bei meinen Snipplets nichts anderes angegeben ist Lizenz: WTFPL)
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.851 Beiträge
 
Delphi 11 Alexandria
 
#8

AW: Vor- und Nachnamen splitten

  Alt 27. Apr 2012, 12:25
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.
Markus Kinzler
  Mit Zitat antworten Zitat
Gustav.R
(Gast)

n/a Beiträge
 
#9

AW: Vor- und Nachnamen splitten

  Alt 27. Apr 2012, 12:43
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

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

GG
  Mit Zitat antworten Zitat
Benutzerbild von Mackhack
Mackhack

Registriert seit: 29. Nov 2003
Ort: San Diego, CA/USA
1.446 Beiträge
 
Delphi 2006 Architect
 
#10

AW: Vor- und Nachnamen splitten

  Alt 27. Apr 2012, 18:57
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
Um etwas Neues zu schaffen muss man seine Ohren vor den Nein-sagern verschliessen um seinen Geist öffnen zu können.
(George Lukas)
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 3  1 23   

Themen-Optionen Thema durchsuchen
Thema durchsuchen:

Erweiterte Suche
Ansicht

Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 16:17 Uhr.
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