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 Tabelle generieren mit Daten aus DB

Mitglied: Jon

Jon (Level 1) - Jetzt verbinden

20.05.2008, aktualisiert 13:40 Uhr, 3977 Aufrufe, 2 Kommentare

Hallo zusammen, ich hoffe jemand kann mir bei einer DB-Abfrage helfen.

Folgendes Konstrukt:
PHP5, MySQL5.x

Datenbank (die relevanten felder):
kurs > kursid | kursnummer | kursname
termine > terminid | kursid | kursdatum
buchung > buchid | terminid

Wie ihr sehen könnt gibt es erst mal verschiedene Kurse, die sich wiederum in verschiedene Termine aufspalten.
Die Termine sind dabei mit kursid an den Kurs verknüpft, die einzelnen Buchungen mit terminid an die Termine.

Was ich jetzt brauche: Eine Matrix, wo nach x die Kurse aufgeführt sind und nach y die Termine.
Als Daten sollen dann die Anzahl der Buchungen stehen.

$x = $db->query("SELECT k.*, t.* FROM kurs k, termine t WHERE k.kursid = t.kursid ORDER BY k.kursnummer");
while ($row = $db->fetch_array($x)){
list($buchcount)=$db->query_first("SELECT COUNT(*) FROM buchung WHERE terminid = $row[terminid]");
echo ("$row[ksnr] > $row[kdate] > $buchcount <br>");
}

Ausgabe:

102030 > 2008-10-11 > 4
102030 > 2008-09-23 > 3
102030 > 2008-10-14 > 0
102030 > 2008-10-15 > 0
102031 > 2008-10-12 > 2
102032 > 2008-10-08 > 1
102032 > 2008-10-12 > 1
102032 > 2008-10-13 > 0



Diese Abfrage funktioniert ja schon mal ganz gut. Nur komm ich jetzt nicht klar, das ganze in eine Tabelle nach oben genannten Kriterien zu werfen. Ich hab dazu schon mehrere while-schleifen versucht, mehrdimensionale Arrays, aber ich bekomm die Ausgabe in eine Tabelle einfach nicht hin.



Ich hoffe ihr wisst ungefähr was ich meine und habt einen Lösungsvorschlag für mich.

Vielen Dank schon mal fürs Ansehen.

mfg
Jon
Mitglied: bytecounter
20.05.2008 um 13:31 Uhr
Hallo,

nun hatte ich das alles schön aufgeschrieben und dann schmeisst mich administrator.de raus (neue Passworteingabe nach dem Absenden und die POST-Daten natürlich futsch *grrrr*).

Daher nochmal auf die Schnelle, ich hoffe, es ist verständlich:

Du kannst über ein mehrdimensionales Array arbeiten:
$tabelle[$zeile][$spalte]

Als erstes die Kopfzeile erzeugen (alle Kurse), 1. Spalte bleibt frei, da diese ja das Datum beinhaltet.
Dann die Datums (ich weiss, das ist sprachlich falsch, aber "Daten" wäre hier irreführend ) in
$tabelle[$zeile][0] speichern

Darauf eine verschachtelte foreach:
foreach zeile {
foreach $spalte {
und hier die DB-Abfrage über Spalten- und Zeilenname
}
}


Das Ganze ist lediglich als Ansatz zu verstehen. Bei vielen Terminen/Kursen wäre das aber ziehmlich Ressourcenfressend. Allerdings müsste man dann schon bei dem vorhandenen DB Design anfangen zu überarbeiten.

vg Bytecounter
Bitte warten ..
Mitglied: Jon
20.05.2008 um 13:40 Uhr
Vielen Dank für den Denkanstoß.
An der Datenbank kann ich nichts ändern, die besteht leider schon und ist mit einer Menge an Daten gefüllt.

Ich hab gerade gesehen, das die DB auch von außen angesprochen werden darf. Mit Access hab ich jetzt über den MyODBC-Treiber die Tabellen eingebunden und eine Kreuztabellenabfrage gemacht. Funktioniert wunderbar
Da es sich hierbei nur um eine interne Auswertung handelt, könnte ich auch damit leben. Mal sehen, ob der Kunde auch damit leben kann... Dafür mach ich ihm ein paar Abfragen extra, mit Access ja kein Problem *hehe*

Danke nochmal für deine Idee!
Bitte warten ..
Ähnliche Inhalte
Microsoft Office

Daten einer MSSQL DB Tabelle in Excel ändern

gelöst Frage von it-froschMicrosoft Office3 Kommentare

Hallo Kollegen, ich habe in einer MSSQL DB eine Tabelle, deren Inhalt täglich als Datenquelle für einen Pflegejob verwendet ...

Java

Daten aus einer mysql DB in Android Studio in einer Tabelle mit Spaltenüberscgrift anzeigen

Frage von helmuthelmut2000Java

Hallo, Ich lasse bis jetzt meine Daten aus einer MySQL Datenbank im Android Studio in einem listview anzeigen. Da ...

Sicherheits-Tools

Sicherheitstest von Passwörtern für ganze DB-Tabellen

Tipp von gdconsultSicherheits-Tools3 Kommentare

Hallo! Ich habe gerade ein nettes kleines Tool fertiggestellt. Damit kann die Passwort-Spalte einer CSV-Datei der reihe nach gehen ...

Microsoft Office

Word Dokument (vorausgefüllte Formulare) aus Excel Tabelle generieren

Frage von Server4AlleMicrosoft Office1 Kommentar

Hallo, gibt es eine Möglichkeit aus einer Excel Tabelle (Datenquelle) heraus mehrere Word Dokument (vorausgefüllte Formulare) zu generieren? Oder ...

Neue Wissensbeiträge
Sicherheit
Adminrechte dank Bug in Intel HD Graphics Treiber
Information von DerWoWusste vor 9 StundenSicherheit

Intel HD graphics 4200 und neuer (4400, 4600 520,530,620, 630,) sind auf jeden Fall betroffen und bereinigte Treiber sind ...

Router & Routing

Endlich: Reines Kabel-TV Modem in D erhältlich !

Information von aqui vor 3 TagenRouter & Routing10 Kommentare

Mit dem Technicolor TC4400-EU Modem sind nun auch Breitband Router ohne integriertes Modem oder Firewalls wie z.B. die pfSense ...

Netzwerkgrundlagen
The Illustrated TLS Connection
Information von Lochkartenstanzer vor 3 TagenNetzwerkgrundlagen1 Kommentar

Moin, Unter findet man eine gelungene Erläuterung von TLS. Fördert sehr das verständnis darüber, was da passiert. lks

Windows 10

Zuverlässiger Remove-AppxProvisionedPackage Ausführen in W10-1803

Tipp von NetzwerkDude vor 5 TagenWindows 104 Kommentare

Moin, Remove-AppxProvisionedPackage hat in 1709 recht zuverlässig funktioniert, in 1803 ist es leider so das es gerne mail failed ...

Heiß diskutierte Inhalte
Windows Server
AD User wird immer wieder gesperrt
Frage von YellowcakeWindows Server20 Kommentare

Hey ich habe einen User (ein GL User - Natürlich was denn sonst) der immer wieder gesperrt wird. Ich ...

Windows Netzwerk
Gruppenrichtlinie für einen PC deaktivieren
gelöst Frage von Florian961988Windows Netzwerk14 Kommentare

Hallo, kleines Problem und immoment finde ich dazu keine Lösung oder mir fällt nicht ein, wie ich es suche ...

Debian
Linux debian 9 Installation
Frage von Green14Debian13 Kommentare

Hallo zusammen, ich habe mich ein wenig mit Debian auseinandergesetzt und möchte mir eine Standard-Installation als Grundlage für andere ...

Switche und Hubs
OpenSource oder Freeware zur Verwaltung von Switchen
gelöst Frage von JonskezSwitche und Hubs12 Kommentare

Hallo, gibt eine kostenlose Verwaltungssoftware für Switche (überwiegend HP/Aruba)? Es sollte möglich sein, aus der Ferne z.B. die Firmware ...