Top-Themen

Aktuelle Themen (A bis Z)

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

MYSQL SPLIT

Frage Entwicklung Datenbanken

Mitglied: Radi1989

Radi1989 (Level 1) - Jetzt verbinden

18.08.2010 um 15:59 Uhr, 3758 Aufrufe, 4 Kommentare

Hallo Leute,

und zwar habe ich folgendes Problem:
Ich muss aus einer Tablle bzw. deren Spalte alle Ziffern raussuchen und sie in eine neue Zeile schreiben. Folglich brauch muss ich jede Zeile auslesen und nach dem ; splitten und im Anschluss jeden einzelnen Wert in eine neue Zeile reinschreiben.


Beispiel-Tabelle: id kennziffern
1 051316;313646;341316;*;
2 458741;123456;*;854875

Da ich leider aber noch Jungfrau in SQL bin, wöre es schön wenn ihr mir helfen könntet. Als Einschränkung gilt noch, das nur SQL verwendet werden darf.

Danke im vorraus für die Hilfe.

Gruß Chris
Mitglied: dog
18.08.2010 um 17:35 Uhr
Ich lehne mich mal aus dem Fenster und sage das ist nur sehr umständlich möglich:

Stichworte:
Stored Procedures
Loops
Cursor
Bitte warten ..
Mitglied: Biber
18.08.2010 um 20:12 Uhr
Moin Radi1989,

wenn dir als einem SQL-Newbie jemand diese Aufgabe übertragen hat, dann liegt der Verdacht nahe, es könnte so eine Art kleiner Scherz von Kollegen gegenüber Frischlingen sein.
So wie der Satz "Hol mal die Frequenzbiegezange aus dem Werkstattwagen!" zum neuen Azubi.

Falls es so ist (wie ich inständig hoffe), dann ..
--> Okay, bist reingefallen. Wir machen einen Haken dran und verschieben es nach "Humor(lol)". Ende der Story.

Falls diejenigen, die dir das aufgedrückt haben, es ernst meinen sollten, sag denen:

  • "Randbedingung nur reines SQL?" :
Kannste knicken.
MySql kennt keine Explode(..) -Funktion und die nächst schwereren Geschütze wären ein kombinierter Gordischer REXEXP()/Instr()-Knoten, den hier im Forum vielleicht 5 Leute LESEN könnten vor Weihnachten.
Aber du mit Sicherheit nicht schreiben
Und selbst wenn das gelänge mit Rückenwind und a little help from friends --> auf dieses unwartbare und inperformante Gestrunkele musst du dann zusätzlich noch ein paar UNION ALLs draufsetzen, damit aus jeder Spalte mit 4 Einträgen dann auch 4 Zeilen in der Anzeige werden... die jagen dich vom Hof, wenn die Laufzeit der Query bekannt wird.

  • eingeschränkt, aber nicht ganz so extrem gilt das auch für eine Lösung mit einer stored procedure, wie von dog genannt oder für ein Abweichen vom Plan "nur SQL" und einer Lösung mit der PHP-explode()-Funktion.

  • und um es ganz ganz deutlich zu sagen: was dort vorliegt ist ein Designfehler. Fehlende Normalisierung. So nicht verarbeitbar im DB-Kontext.

  • FALLS das eine gelieferte Datei zum Import ist: Ablehnen. Back to sender.. Zahlung an den Datenlieferanten einstellen. Rechtsschutz anrufen.

Wie geschrieben - ich hoffe für alle Beteiligten, dass es nur ein Ulk unter Kollegen ist.

Grüße
Biber
Bitte warten ..
Mitglied: Radi1989
19.08.2010 um 08:21 Uhr
Danke für den Tipp dog.

Und biber, nein es ist leider kein Scherz. Es soll nur reines SQL verwendet werden und das alles im Zusammenhang mit Stored Procedure.
Aber fand deinen Kommentar trotzdem super ;) :D.

Na dann muss ich mal gucken wie ich das anstelle...

Danke für die Hilfe

LG Radi
Bitte warten ..
Mitglied: 93045
19.08.2010 um 10:53 Uhr
Also... so was wie SPLIT gibt es nicht. Wenn man sich aber die mysql Referenz Dokumentation anschaut, findet man Funktionen wie LOCATE und SUBSTR mit denen man sich ein SPLIT zusammenbauen kann. Googelt man dann noch ein wenig, findet man z.B. diesen Thread: http://forums.mysql.com/read.php?60,78776,78776#msg-78776. Ganz wichtig ist den gesamten Thread durchzulesen.
Allerdings bleibt die Frage offen, wie sinnvoll das alles (Datenbank-Design, Stored Procedure) eigentlich ist.
Bitte warten ..
Ähnliche Inhalte
Router & Routing
Open VPN auf Split konfiguriren
Frage von rainergugusRouter & Routing9 Kommentare

Hallo, früher mit W7 ging Open VPN immer Tadellos. Nun mit Windows 10 schliesst das Open VPN immer unseren ...

Batch & Shell
Powershell - Regex - Split
gelöst Frage von internet2107Batch & Shell1 Kommentar

Hallo zusammen. Ich lese Variablen über eine .ini Datei ein. Innerhalb der .ini-Datei sieht es dann als Beispiel so ...

Windows Server
Split DNS auf ReadOnly DC
gelöst Frage von winlinWindows Server15 Kommentare

Ich habe eine externe und eine interne Zone. In der internen Zone stehen zwei ReadWrite DC´s sowie zwei ReadOnly ...

Windows Server
Split brain DNS konfigurieren
Frage von winlinWindows Server5 Kommentare

Weil man hier von euch so super tipps bekommt hoffe ich das ihr mir beim split DNS helfen könnt. ...

Neue Wissensbeiträge
Windows 10

Autsch: Microsoft bündelt Windows 10 mit unsicherer Passwort-Manager-App

Tipp von kgborn vor 1 TagWindows 107 Kommentare

Unter Microsofts Windows 10 haben Endbenutzer keine Kontrolle mehr, was Microsoft an Apps auf dem Betriebssystem installiert (die Windows ...

Sicherheits-Tools

Achtung: Sicherheitslücke im FortiClient VPN-Client

Tipp von kgborn vor 1 TagSicherheits-Tools

Ich weiß nicht, wie häufig die NextGeneration Endpoint Protection-Lösung von Fortinet in deutschen Unternehmen eingesetzt wird. An dieser Stelle ...

Internet

USA: Die FCC schaff die Netzneutralität ab

Information von Frank vor 2 TagenInternet5 Kommentare

Jetzt beschädigt US-Präsident Donald Trump auch noch das Internet. Der neu eingesetzte FCC-Chef Ajit Pai ist bekannter Gegner einer ...

DSL, VDSL

ALL-BM200VDSL2V - Neues VDSL-Modem mit Vectoring von Allnet

Information von Lochkartenstanzer vor 2 TagenDSL, VDSL2 Kommentare

Moin, Falls jemand eine Alternative zu dem draytek sucht: Gruß lks

Heiß diskutierte Inhalte
Batch & Shell
Kann man mit einer .txt Datei eine .bat Datei öffnen?
gelöst Frage von HelloWorldBatch & Shell20 Kommentare

Wie schon im Titel beschrieben würde ich gerne durch einfaches klicken auf eine Text oder Word Datei eine Batch ...

Router & Routing
OpenWRT bzw. L.E.D.E auf Buffalo WZR-HP-AG300H - update
gelöst Frage von EpigeneseRouter & Routing11 Kommentare

Guten Tag, ich habe auf einem Buffalo WZR-HP-AG300H die alternative Firmware vom L.E.D.E Projekt geflasht. Ich bin es von ...

LAN, WAN, Wireless
WLAN Reichweite erhöhen mit neuer Antenne
gelöst Frage von gdconsultLAN, WAN, Wireless8 Kommentare

Hallo, ich besitze einen TL-WN722N USB-WLAN Dongle mit einer richtigen Antenne. Ich frage mich jetzt ob man die Reichweite ...

Windows Server
Ping auf einen bestimmten Server nicht möglich
gelöst Frage von a.thierWindows Server7 Kommentare

Hallo, ich habe folgendes Problem. srv-dc1: Ping srv-nav > geht Ping srv-exchange > geht nicht srv-exchange: Ping srv-dc1 > ...