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

In MySQL Variableninhalt zu Spaltendefinition machen

Frage Entwicklung Datenbanken

Mitglied: lupi102

lupi102 (Level 1) - Jetzt verbinden

28.03.2013, aktualisiert 10:26 Uhr, 1208 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 Liste simulieren (2)

Frage von Yanmai zum Thema Datenbanken ...

Datenbanken
MySQL bearbeiten - Rechte auf User ändern (6)

Frage von istike2 zum Thema Datenbanken ...

Datenbanken
MySQL - Mehrere Instanzen

Frage von ForgottenRealm zum Thema Datenbanken ...

Verschlüsselung & Zertifikate
Zugriff auf mySQL-DB mit ODBC und SSL (2)

Frage von Titan24 zum Thema Verschlüsselung & Zertifikate ...

Neue Wissensbeiträge
Windows Update

Microsoft Update KB4034664 verursacht Probleme mit Multimonitor-Systemen

Tipp von beidermachtvongreyscull zum Thema Windows Update ...

Viren und Trojaner

CNC-Fräsen von MECANUMERIC werden (ggf.) mit Viren, Trojanern, Würmern ausgeliefert

(4)

Erfahrungsbericht von anteNope zum Thema Viren und Trojaner ...

Windows 10

Windows 10: Erste Anmeldung Animation deaktivieren

(3)

Anleitung von alemanne21 zum Thema Windows 10 ...

Heiß diskutierte Inhalte
Router & Routing
gelöst Linksys wrt1200ac v2 mit dd-wrt: keine vlan-einstellungen im GUI (15)

Frage von Pixi123 zum Thema Router & Routing ...

E-Business
Wo tragt ihr eure privaten Termine ein? (13)

Frage von honeybee zum Thema E-Business ...

Batch & Shell
Batch zum suchen und verschieben von Verknüpfungen (12)

Frage von zeroblue2005 zum Thema Batch & Shell ...

Windows Server
Terminalserver starten willkürlich neu (12)

Frage von thaefliger zum Thema Windows Server ...