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

In MySQL Variableninhalt zu Spaltendefinition machen

Frage Entwicklung Datenbanken

Mitglied: lupi102

lupi102 (Level 1) - Jetzt verbinden

28.03.2013, aktualisiert 10:26 Uhr, 1213 Aufrufe, 2 Kommentare

Hallo alle,

Ich habe eine Tabelle "messzähler" in der u.a. gespeichert wird, wann ein bestimmtes Bauteil gemessen wird. Da jedoch projektspezifische Anpassungen erfolgen müssen, will ich diese Daten in eine separate Tabelle "specials" auslagern und sie anschließend mittels JOIN wieder verbinden. Bis hierhin kein Problem, aber: eine Abfrage von messzähler in Verbindung mit specials gibt logischerweise soviele Zeilen aus wie betreffende Zeilen in specials vorhanden sind. Das will ich so aber nicht. Ich möchte, dass alles in einer Zeile steht.
Dazu dachte ich eine temporäre Tabelle zu erstellen, in der Zellinhalte (z.B.: Lieferdatum) zur Spaltendefinition in einem "ALTER TABLE" Statement werden.
Mein Weg im Moment ist:

CREATE PROCEDURE JoinMzAndSpecials(inlfdnr MEDIUMINT) -- inlfdnr ist die laufende Bauteilnummer
BEGIN
DECLARE done INT DEFAULT 0;
DECLARE spalte VARCHAR(45);
DECLARE cur1 CURSOR FOR SELECT name FROM specials WHERE lfdnr=inlfdnr;
DECLARE CONTINUE HANDLER FOR SQLSTATE '02000' SET done = 1;

CREATE TABLE temp (dkwnum VARCHAR(13),
lfdnr INT,
messdat DOUBLE,
fertdat INT,
liefdat INT) ENGINE=MEMORY;

OPEN cur1;

REPEAT
FETCH cur1 INTO spalte;

IF NOT done THEN
ALTER TABLE temp ADD spalte VARCHAR(45);
END IF;
UNTIL DONE
END REPEAT;
END
$$

Das Problem hierbei ist, dass 'spalte' als Spaltenbezeichner angesehen wird, sodass 'spalte' zur Tabelle hinzugefügt wird, was bei mehrfachem Durchlauf der REPEAT- Schleife natürlich nicht funktioniert.
Wie kann ich 'spalte' so umbiegen, dass der Variableninhalt als Spaltenbezeichner verwendet wird?

Grüße
Heiko
Mitglied: SlainteMhath
28.03.2013 um 11:21 Uhr
Moin,

versuch's mal hiermit:
01.
SET @s = CONCAT('ALTER TABLE temp ADD', spalte, ' VARCHAR(45); ');  
02.
PREPARE stmt1 FROM @s;  
03.
EXECUTE stmt1;  
04.
DEALLOCATE PREPARE stmt1; 
lg,
Slainte
Bitte warten ..
Mitglied: lupi102
28.03.2013 um 11:30 Uhr


Funktioniert!

Danke
Heiko
Bitte warten ..
Ähnliche Inhalte
Datenbanken
MySQL Profiler - MySQL Profiling
Frage von fckoelleDatenbanken

Hallo zusammen, ich möchte zu Analysezwecken gerne herausfinden welche Befehle auf einen MySQL Server abgesetzt werden. Von Microsoft kenne ...

Datenbanken
CURDATE() MySQL
gelöst Frage von ThoomaasDatenbanken1 Kommentar

Hallo alle zusammen, ich habe das Problem, dass wenn ich eine Abfrage aus einer DB mache mit dem String ...

Webentwicklung
Mysql cluster
Frage von woidl85Webentwicklung

hallo zusammen, ich bin auf der suche nach einer mysql cluster lösung aus 2 nodes welche bei möglichkeit mit ...

Datenbanken
MYSQL ausgabe
Frage von pcguyDatenbanken31 Kommentare

Hallo zusammen Ich versuche gerade einen DB inhalt gefiltert auszugeben. DB: id - parent_id - title - url - ...

Neue Wissensbeiträge
Viren und Trojaner

Deaktivierter Keylogger in HP Notebooks entdeckt

Information von bitcoin vor 14 StundenViren und Trojaner1 Kommentar

Ein Grund mehr warum man Vorinstallationen der Hersteller immer blank bügeln sollte Der deaktivierte Keylogger findet sich im vorinstallierten ...

Router & Routing

Lets Encrypt kommt auf die FritzBox

Information von bitcoin vor 18 StundenRouter & Routing

In der neuesten Labor-Version der FB7490 integriert AVM unter anderem einen Let's Encrypt Client für Zugriffe auf das Webinterface ...

Internet

Was nützt HTTPS, wenn es auch von Phishing Web-Seiten genutzt wird

Information von Penny.Cilin vor 3 TagenInternet17 Kommentare

HTTPS richtig einschätzen Ob man eine Webseite via HTTPS aufruft, zeigt ein Schloss neben der Adresse im Webbrowser an. ...

Webbrowser

Bugfix für Firefox Quantum released - Installation erfolgt teilweise nicht automatisch!

Erfahrungsbericht von Volchy vor 4 TagenWebbrowser8 Kommentare

Hallo zusammen, gem. dem Artike von heise online wurde mit VersionFirefox 57.0.1 sicherheitsrelevante Bugs behoben. Entgegen der aktuellen Veröffentlichung ...

Heiß diskutierte Inhalte
Batch & Shell
Trusted Sites für alle User auf dem PC einpflegen
Frage von xXTaKuZaXxBatch & Shell12 Kommentare

Aufgabestellung: Es sollen auf 1 PC (bzw. mehreren PCs) vertrauenswürdige Sites per Powershell eingetragen werden, die für alle User ...

Voice over IP
Telefonstörung - Ortsrufnummern kein Verbindungsaufbau
Frage von Windows10GegnerVoice over IP10 Kommentare

Hallo, sowohl bei uns als auch beim Opa ist es über VoIP nicht möglich Ortsrufnummern anzurufen. Es kommt nach ...

Vmware
DOS 6.22 in VMWare mit CD-ROM
gelöst Frage von hesperVmware10 Kommentare

Hallo zusammen! Ich hab ein saublödes Problem. Es ist eine VMWare mit DOS 6.22 zu erstellen auf dem ein ...

Cloud-Dienste
PIM als SaaS Nutzungsgebühr
Frage von vanTastCloud-Dienste8 Kommentare

Moin, wir haben uns ein PIM (Product Information Management) nach unseren Ansprüchen für viel Geld als SaaS-Lösung bauen lassen. ...