Top-Themen

AppleEntwicklungHardwareInternetLinuxMicrosoftMultimediaNetzwerkeOff TopicSicherheitSonstige SystemeVirtualisierungWeiterbildungZusammenarbeit

Aktuelle Themen

Administrator.de FeedbackApache ServerAppleAssemblerAudioAusbildungAuslandBackupBasicBatch & ShellBenchmarksBibliotheken & ToolkitsBlogsCloud-DiensteClusterCMSCPU, RAM, MainboardsCSSC und C++DatenbankenDatenschutzDebianDigitiales FernsehenDNSDrucker und ScannerDSL, VDSLE-BooksE-BusinessE-MailEntwicklungErkennung und -AbwehrExchange ServerFestplatten, SSD, RaidFirewallFlatratesGoogle AndroidGrafikGrafikkarten & MonitoreGroupwareHardwareHosting & HousingHTMLHumor (lol)Hyper-VIconsIDE & EditorenInformationsdiensteInstallationInstant MessagingInternetInternet DomäneniOSISDN & AnaloganschlüsseiTunesJavaJavaScriptKiXtartKVMLAN, WAN, WirelessLinuxLinux DesktopLinux NetzwerkLinux ToolsLinux UserverwaltungLizenzierungMac OS XMicrosoftMicrosoft OfficeMikroTik RouterOSMonitoringMultimediaMultimedia & ZubehörNetzwerkeNetzwerkgrundlagenNetzwerkmanagementNetzwerkprotokolleNotebook & ZubehörNovell NetwareOff TopicOpenOffice, LibreOfficeOutlook & MailPapierkorbPascal und DelphiPeripheriegerätePerlPHPPythonRechtliche FragenRedHat, CentOS, FedoraRouter & RoutingSambaSAN, NAS, DASSchriftartenSchulung & TrainingSEOServerServer-HardwareSicherheitSicherheits-ToolsSicherheitsgrundlagenSolarisSonstige SystemeSoziale NetzwerkeSpeicherkartenStudentenjobs & PraktikumSuche ProjektpartnerSuseSwitche und HubsTipps & TricksTK-Netze & GeräteUbuntuUMTS, EDGE & GPRSUtilitiesVB for ApplicationsVerschlüsselung & ZertifikateVideo & StreamingViren und TrojanerVirtualisierungVisual StudioVmwareVoice over IPWebbrowserWebentwicklungWeiterbildungWindows 7Windows 8Windows 10Windows InstallationWindows MobileWindows NetzwerkWindows ServerWindows SystemdateienWindows ToolsWindows UpdateWindows UserverwaltungWindows VistaWindows XPXenserverXMLZusammenarbeit
GELÖST

SQL String zerlegen

Frage Entwicklung Datenbanken

Mitglied: Antos

Antos (Level 1) - Jetzt verbinden

08.09.2008, aktualisiert 09.09.2008, 17468 Aufrufe, 2 Kommentare

Hat einer ne Idee wie ich am besten 'n String zerhack? MSSQL

Hallo zusammen,

ich steh vor folgender Herausforderung. Ich hab eine Tabelle in der sich eine Spalte string befindet. Ein Wert sieht z.B. so aus:

AWUVUZ,30-0-0,PräfEG,AE-MiK

oder

AWUVUZ,PräfEG,AE-MiK,60-0-0,Z4-PU

Ich brauche jetzt aus dem String den "Zahlenwert". Also aus dem ersten '30-0-0', aus dem zweiten '60-0-0' für eine Abfrage in einer anderen Tabelle.
Hat einer eine Idee wie ich jeweils die Substring's von Komma zu Komma auslesen kann?

erstens = substring(SPALTE, 0, CHARINDEX(',', SPALTE))

gibt mir leider nur den String bis zum ersten Komma aus, keine Ahnung wie ich da ein Komma weiterspringen kann.
Das zweite wäre evtl. mit LEFT-RIGHT zu bewerkstelligen, aber die Anzahl der Kommas sind nicht festgelegt.Daher mal 5, mal 3 usw.
Für Tipps bin ich dankbar!
mfg
Antos
Mitglied: SvenGuenter
08.09.2008 um 17:33 Uhr
Versuch mal diese Funktion. Einfach anlegen und string übergeben

01.
CREATE FUNCTION [dbo].[splitfunction] 
02.
03.
 @Position INTEGER, 
04.
 @List VARCHAR(2000),   
05.
 @Delimiter VARCHAR(1) 
06.
07.
RETURNS VARCHAR(2000)  
08.
AS 
09.
BEGIN 
10.
 DECLARE @RetVal VARCHAR(2000) SET @RetVal = ''   
11.
 DECLARE @Counter  INT SET @Counter = 0 
12.
 DECLARE @StartPos INT 
13.
 DECLARE @Length INT 
14.
 DECLARE @DelimPos INT SET @DelimPos = 0 
15.
 
16.
 WHILE @Counter < @Position 
17.
  BEGIN 
18.
   SET @Counter = @Counter + 1   -- zaehler 
19.
   SET @StartPos = @DelimPos + 1 -- startposition 
20.
   SET @DelimPos = CHARINDEX(@Delimiter,@List,@DelimPos + 1)   --nächsten Delimiter finden 
21.
    
22.
   IF @DelimPos = 0 
23.
   BEGIN 
24.
     
25.
    IF @Counter = @Position SET @Length = (LEN(@List)+1)-@StartPos 
26.
 
27.
    ELSE SET @Length = -1 
28.
   END 
29.
   ELSE SET @Length = @DelimPos - @StartPos   
30.
  END 
31.
  -- Rückgabe des Strings 
32.
  IF @Length > 0 SET @RetVal = SUBSTRING(@List,@StartPos,@Length) 
33.
  RETURN @RetVal 
34.
END
Bitte warten ..
Mitglied: Antos
09.09.2008 um 08:27 Uhr
Vielen Dank SvenGuenter ,
funkt einwandfrei!!

mfg
Bitte warten ..
Neuester Wissensbeitrag
Microsoft Office

MS Office Excel - Formel wird angezeigt, aber nicht berechneter Wert!

Tipp von holli.zimmi zum Thema Microsoft Office ...

Ähnliche Inhalte
Batch & Shell
gelöst PowerShell String zerlegen in Array, DataTable, Hashtable speichern (7)

Frage von derhoeppi zum Thema Batch & Shell ...

Datenbanken
gelöst SQL - mehrere UPDATE-Anweisungen in einem String per vbs (4)

Frage von goodbytes zum Thema Datenbanken ...

Datenbanken
gelöst Hilfe bei SQL-Abfrage (5)

Frage von emeriks zum Thema Datenbanken ...

Windows Server
SQL Server sichern in Azure (2)

Frage von xxlukasxx zum Thema Windows Server ...

Heiß diskutierte Inhalte
Hyper-V
gelöst Reiner Hyper- V Server oder lieber Rolle (15)

Frage von Winuser zum Thema Hyper-V ...

Windows Server
gelöst Rechte als Admin vergeben - Zugriff verweigert (14)

Frage von Ghost108 zum Thema Windows Server ...

Router & Routing
gelöst IP Kamera für drei unabhängige Netzwerke (12)

Frage von ProfessorZ zum Thema Router & Routing ...