Tabelle erstellen mit mit "undefinierter" Spaltenanzahl ?
am 30.08.2011 - 20:09 Uhr in
ich möchte eine Tabelle erstellen mit einer vorher nicht definierten Spaltenanzahl.
Die Daten werden aus mehreren Tabellen geholt und sollen zu einer vereint werden, dabei sind die ersten 2 Spalten (ID Name) fest. Die nächsten Spalten sind dynamisch, d.h. es können keine , 1 oder auch 10 werden.
Beispiel:
ID Name Wert1 Wert2 Wert3
1 test 3 4 6
2 last 2 8 9
Die Werte 1, 2, 3 sollen dabei die Anzahl der Einträge sein.
Für die Überschriften funktioniert es soweit mit folgendem Code:
<?php
$w_query = db_select('wert', 'w')
->fields('w', array('id', 'name'))
->execute();
$header[] = array('data' => t('ID'), 'field' => 'id');
$header[] = array('data' => t('Name'), 'field' => 'name');
foreach ($w_query as $w_col) {
$header[] = array('data' => $w_col->name, 'field' => $w_col->id);
}
?>Nur leider scheitern all meine Versuche bei den Zeilen.
<?php
$query = db_select('name', 'n');
$query->extend('TableSort') //Sorting Extender
->orderByHeader($header)
->fields('n', array('id', 'name'));
$rows = array();
$results = $query->execute();
foreach ($results as $row) {
foreach ($w_query as $w_col) {
$daten[] = array(
'data' => array(
db_query('Select Count(id) FROM {daten} WHERE rid=' . $row->id . ' AND gid=' . $w_col->id)->fetchField()
));
}
$row_n[] = array(
'data' => array(
$row->id,
$row->name
));
$rows = array_merge($row_n, $daten);
}
return theme('table', array('header' => $header, 'rows' => $rows));
?>Hat jemand eine Idee? Bin echt festgefahren und wahrscheinlich betriebsblind.
- Anmelden oder Registrieren um Kommentare zu schreiben

Dynamische Spalten
am 30.08.2011 - 22:18 Uhr
Hallo code404,
ich bin jetzt nicht der DB-Profi, aber ich würde das so wie CCK lösen:
1. Tabelle "parents" mit Felder: "id" und "name"
2. Tabelle "children" mit Felder: "id" des Wertes, "id_parent" -> entspricht id in Tabelle 1, und "wert"
Sepp
Hi Sepp, Mit deiner Idee kann
am 31.08.2011 - 09:48 Uhr
Hi Sepp,
Mit deiner Idee kann ich leider nichts anfangen, weiß nicht wie du es meinst.
Ich habe den logischen Fehler in meinem Script gefunden, komm aber trotzdem nicht weiter.
die Schleife schreibt natürlich alle Daten in neue Arrays, sodaß ich folgende Ausgabe bekomme:
ID Name Wert1 Wert2 Wert3
3
4
6
2
8
9
1 test
2 last
anstatt
ID Name Wert1 Wert2 Wert3
1 test 3 4 6
2 last 2 8 9
<?php
foreach ($w_query as $w_col) {
$daten[] = array(
'data' => array(
db_query('Select Count(id) FROM {daten} WHERE rid=' . $row->id . ' AND gid=' . $w_col->id)->fetchField()
));
}
?>